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INTRODUCTION 



This system reference manual presents the 
technical details about the general architec- 
ture, the components, and the subsystems of 
the Burroughs B 7700 Information Processing 
System, which is the most advanced, the larg- 
est, and the most powerful member of the 
Burroughs family of 700 systems. For a more 
general coverage of the hardware and soft- 
ware characteristics of the system, refer to 
the system characteristics manual. 

The chapters of this reference manual are 
as follows: 

Chapter I, Description of the B 7700 System, 
introduces the idea of the interaction of inde- 
pendently operating computing, input/output, 
and memory modules through an exchange 
and a presentation of the range of configura- 
tions of the system. 

Chapter II, System Architecture, discusses 
data representation, Polish notation and stack 
concepts, processor control words, and the con- 
cepts of the input/output subsystem map. 

Chapter III, Central Processor Module, con- 
tains a functional description of the operation 



of the central processor module, an explana- 
tion of hardware interrupts, and a brief de- 
scription of each program operator. 

Chapter IV, Input/Output Subsystem, con- 
tains a general description of the operation of 
the input/output module, functional descrip- 
tions of the subsections of the input/output 
module, and detailed descriptions of the con- 
trol words and descriptors associated with 
each type of peripheral device that may be in- 
cluded in the system. 

Chapter V, Memory Subsystem, a general de- 
scription of the memory subsystem and details 
about both the memory control module and 
the memory storage unit. 

Chapter VI, Controls and Indicators, con- 
tains detailed descriptions of the functions 
and uses of the controls and indicators of the 
central components of the system. 

The term "software", as used in this manual, 
applies to that category of Burroughs Pro- 
gram Products defined as "Systems Software." 

Other categories of Burroughs Program 
Products are: 

Application Program Products 
Program Product Conversion Aids 
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MEMORY MODULES 




CPM - CENTRAL PROCESSOR MODULE 

IOM - INPUT/OUTPUT MODULE 

MDU - MAINTENANCE DIAGNOSTIC UNIT 



Figure 1-1. B 7700 Exchange 
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CHAPTER I 



DESCRIPTION OF B 7700 SYSTEM 



THE B 7700 SYSTEM 

The Burroughs B 7700 Information Process- 
ing System is a large-scale, truly general-pur- 
pose, balanced, flexible, multiprogramming 
and multiprocessing computing system that is 
suitable for such diverse applications as time 
sharing, scientific problem solving, and busi- 
ness data processing. Carrying forward ideas 
proven successful in the Burroughs B 5700 
and B 6700 information processing systems, 
the B 7700 is, in fact, completely code 
compatible with the B 6700 and affords Bur- 
roughs users the opportunity for growth with- 
out reprogramming or recompiling. 

In other words, object code users' programs 
that can be executed successfully on the 
B 6700 can be executed without modification 
on the B 7700, and the; object code that can be 
executed on the B 7700 can be executed with- 
out modification on the B 6700. Nevertheless, 
the B 7700 is designed to satisfy the increas- 
ingly complex data processing needs of the 
years to come. The system is able to handle 
complex data structures and sophisticated pro- 
gram structures dictated both by higher-level 
languages now in use and by the requirements 
of advanced problems, is able to manage effi- 
ciently the massive on-line and archival stor- 
age requirements of large data bases, and is 
able to accommodate vast networks of data 
communications devices. 

A very fast, modular parallel processing sys- 
tem with exception versatility in configura- 
tion, the B 7700 can be tailored to the process- 
ing needs of a user by arranging central proc- 
essor modules, input/output modules, and 
memory modules on a electronic grid, or ex- 
change (figure 1-1), in a variety of ways de- 
pending upon the exact needs of the user. If 
the high performance and adaptability of the 
B 7 700 could be attributed to single factor, it 
would be to the balance attained by means of 
the controlled interaction of independently op- 
erating computing, input/output, and memory 
modules through the exchange. Thus, the 
throughput of the system as a whole is 
maximized, and the performance of no single 
element of the system is maximized to the ne- 
glect or detriment of others. 

The key to the efficient balanced use of the 
system is the Burroughs master control pro- 
gram (MCP)a unique executive software oper- 
ating system that automatically makes opti- 
mum use of all system resources. It is this op- 
erating system that nuakes multiprogramming 



and multiprocessing both functional and prac- 
tical by dynamically controlling system re- 
sources and by scheduling jobs in the multi- 
programming mix. In use, the master control 
program allocates system resources to meet 
the needs of the programs introduced into the 
computer. It continually and automatically 
reassigns resources, starts jobs, and monitors 
their performance. 

Further implications of the modularity and 
flexibility of the system are its expandability 
(a capacity to add hardware modules without 
reprogramming) and its increased reliability 
(and thus increased availability to the user. 
This reliability is achieved by the use of fail- 
soft techniques that (in addition to providing 
for error detection and error correction, redun- 
dancy of data paths, and independence and re- 
dundancy of power supplies) exclude faulty 
modules from the system and permit process- 
ing to continue (again, without reprogram- 
ming) even with a temporarily reduced config- 
uration. 

Even though it is very large and immensely 
complicated, the B 7700 is, nevertheless, com- 
prehensible to the persons who use it: pro- 
gramming is done only in higher-level, prob- 
lem-oriented languages (COBOL, ALGOL, 
FORTRAN, PL/1, and ESPOL); the control 
language used in entering jobs into the system 
is a simple, free-form, English-like language; 
and the messages that pass between the sys- 
tem and the operator are brief, clear, and easy 
to learn. 

DISTINGUISHING FEATURES 

Although the balanced use of the principal 
components of the system as a whole under 
the control and coordination of the master 
control program is the key to the high 
throughput of the B 7700, the high perform- 
ance of the system is in large part achieved by 
improving the speed of execution of instruc- 
tions, by reducing or masking the overhead as- 
sociated with references to memory, by freeing 
the central processor from concern with input/ 
output operations, and by employing fail-soft 
measures that minimi2:e system degradation. 

Because system main-frame hardware has 
been designed and built strictly according to 
stringent circuit and wiring rules and proven 
design and packaging techniques and because 
its processing elements incorporate monolithic 
integrated circuits, the B 7700 system per- 
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forms consistently at high operating frequen- 
cies: the central processor module at a clock 
rate of 16 megahertz and the remainder of the 
system at 8 megahertz. 

By combining the following features with 
the high internal operating frequencies, the 
performance of the system is further en- 
hanced. 

1. The parallel and independent operation of 
the three main sections (program, execution, 
and storage) of the central processor module. 
This parallelism (coupled with the high clock 
rate) makes possible the speeding up of arith- 
metic computations and data manipulations 
and the overlapping of these computations and 
manipulations with memory references. 

2. A special high-speed integrated circuit 
memory (program, stack, and associative data 
buffers). This high-speed local memory permits 
multiword transfers between the central proc- 
essor and main memory and makes possible 
the anticipation of the need for program and 
data words. Hence, the time spent waiting for 
the completion of transfers to and from 
memory is reduced and at times virtually elim- 
inated. 

3. The four-way interleaving of addresses in 
main memory and the capability for phased 
multiword transfers of information to and 
from memory in groups of up to four words. 
Consequently, memory access times for each 
user of memory are reduced, and memory is 
thus made more accessible to all users. 

4. The asynchronous performance of input/ 
output operations by the input/output module 
independent of the central processor, which is 
therefore freed to do other useful work. 

The three goals of the fail-soft features of 
the B 7700 are to keep the system running 100 
percent of the time, to minimize system degra- 
dation, and to provide the user with tools for 
performing his own data recovery. These goals 
are achieved by the artful combination of 
hardware and software throughout the sys- 
tem. 

The first goal, to keep running, is achieved 
as follows: 

1. By the high reliability of system hard- 
ware. 

2. By the incorporation of error detection 
circuits throughout the system. 

3. By single-bit error correction of errors in 
memory. 

4. By recording errors for software analysis. 

5. By modular design, by use of separate 
power supplies and redundant regulators for 
each module, and by use of redundant buses. 

6. By the ability of the master control pro- 
gram to reconfigure the modules of the system 
to exclude temporarily a faulty module. 



7. By automatic instruction retry, if a hard- 
ware malfunction occurs during the perform- 
ance of an instruction, the master control pro- 
gram analyzes the error and writes the appro- 
priate entry in the on-line maintenance log. 
The processor is reset to its state prior to the 
error and the instruction is performed again. 

In short, the detection and reporting of er- 
rors is done by hardware, analysis of errors is 
done by software, and the reconfiguration of 
the system is done dynamically by software. 
Because of the modularity of power supplies 
and the use of redundant regulated supplies 
for critical voltages, the impact of a malfunc- 
tioning dc supply is minimized and does not re- 
sult in a catastrophic failure. 

The second goal, to minimize system degra- 
dation, is achieved by providing diagnostic pro- 
grams and equipment for rapidly identifying 
and repairing faults and for reestablishing 
confidence in a repaired module before it is re- 
turned to the user's system. The diagnostic 
programs of the B 7700 system identify a fau- 
lty module. By the use of the maintenance di- 
agnostic unit, a fault in any main-frame mod- 
ule or in a disk file optimizer is narrowed to a 
single clock period and to a flip-flop and its as- 
sociated the central processor module, the in- 
put/output the card tester on the maintenance 
diagnostic unit, the faulty integrated circuit 
chip is identified. 

The third goal, to provide the user with tools 
for performing his own data recovery, is 
achieved by the use of such features as instal- 
lation allocated disk, protected disk files, dupli- 
cated disk files, and fault statements in the 
higher-level programming languages used on 
the system. 

Installation allocated disk allows the user to 
specify the physical allocation of his critical 
disk files to facilitate the maintenance and re- 
construction of these files. Protected disk files 
allow a user to gain access to the last portion 
of valid data written in a file before an unex- 
pected system halt. The use of duplicated disk 
files is to avoid the problem of fatal disk file 
errors. The master control program maintains 
more than one copy of each disk file row, and, 
if access cannot be gained to a record, an at- 
tempt is made to gain access to a copy of the 
record. By use of fault statements, the user 
can stipulate actions to be taken by his pro- 
grams in the event errors occur. 

SYSTEM CONFIGURATION 

Physically, the components of the B 7700 
system fall into three categories, as follows: 

1. Central components of the B 7700 system: 
the central processor module, input/output 
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output module, the memory module, the main- 
tenance diagnostic unit, and the operator's 
console (refer to table 1-1). 

2. Standard Burroughs cabinets that con- 
tain peripheral controls and exchanges, the 
disk file optimizer, the data communications 
processor, and ac power supplies. 

3. Standard peripheral devices that are 
joined to the central system by means of 
standard Burroughs peripheral controls, 
adapters, and exchanges and standard remote 
devices that are joined to the central system 
by means of line adapters and data communi- 
cations processor. 

The arrangement of these components into a 
system and the size of the system depend on 
the application and workload of the user. In 
the following paragraphs, the range of config- 
urations of the B 7700, the maximum 
configuration and the minimum configuration, 
is described. 



Table 1-1. 

Style No. 

B 7750 



B 7760 



B 7770 



Central Components of the B 7700 
System 

Description 

System includes: one central processor (16 
MHz with vectors), one input/output 
processor with 24 data switching channels, 
one maintenance diagnostic unit, one 
operator console with dual displays and 
control. 

System includes: two central processors (16 
MHz with vectors, two input/output 
processors with 24 data switching channels 
each, one maintenance diagnostic unit, one 
operator console with dual displays and 
control. 

System includes: three central processors 
(16MHz with vectors), two input/output 
processors with 24 data switching channels 
each, one maintenance diagnostic unit, one 
operator console with dual displays and 
control. 

System includes; four central processors (16 
MHz with vectors), two input/output 
processors with 24 data switching channels 
each, one maintenance diagnostic unit, one 
operator console with dual displays and 
control. 

Basic memory module - 1.5 megabytes of 88 
ns/byte read access, error-correcting 
memory, four-w;»y interleaving that permits 
four-word transfers to and from memory. 

Additional central processor. 

Additional input/output processor. 



CONFIGURATION 

Figure 1-2 illustrates the theoretical 
maximum configuration of the B 7700 system. 



B 7780 



B 7001-4 

: 


B 7702 


B 7785 


MAXIMUM 



As many as eight memory modules may be ar- 
ranged on the exchange with a combined total 
of up to eight requestors of memory-central 
processor modules and input/output modules. 
Any single requestor of memory may address 
and gain access to the entire contents of high- 
speed main memory (1,048,576 words, or 
6,291,456 eight-bit bytes). On the maintenance 
bus (which services the memory control mod- 
ules, central processor modules, input/output 
modules, and disk file optimizers) one or two 
maintenance diagnostic units may be placed. 

At rates of up to 6.75 million bytes per sec- 
ond, a single input/output module is capable of 
transferring data simultaneously between 
main memory and 28 peripheral controls (in- 
cluding eight high-speed controls) and between 
main memory and as many as four data com- 
munications processors. It is also capable of 
handling as many as four disk file optimizers 
(devices that are used in improving the rate of 
transfer of data between main memory and 
disk files). At present, the maximum number 
of high-speed, medium-speed, and low-speed 
peripheral devices that may be attached 
through controls and exchanges to a single in- 
put/output module or that may be included in 
the input/output subsystem of the B 7700 is 
255. (Each card reader, pseudoreader, card 
punch, line printer, paper tape reader, paper 
tape punch, operator's display terminal, and 
free-standing magnetic tape unit; each station 
on a magnetic tape cluster; and each electron- 
ics unit in a disk file subsystem is considered 
a device.) By suitable cross-connection through 
exchanges, it is possible to establish pathways 
between disk files, disk packs, or magnetic 
tape units and more than one input/output 
module; hence, these peripheral devices can be 
shared by all of the input/output modules in 
the system. 

Among the peripheral devices available are 
disk file and disk pack memory modules that 
constitute a virtual memory that in effect 
greatly expands the storage capacity of the 
main memory of the system; these modules, 
which are interfaced with the input/output 
module through controls are as follows: 

1. Head-per-track disk file modules that are 
combined under the control of disk file opti- 
mizers to form optimized-access memory 
banks capable of storing from 450 million to 8 
billion eight-bit bytes of information per input/ 
output module and whose access time is as low 
as 2-to-6 milliseconds. 

2. Head-per-track disk file modules that are 
combined (without the control of the opti- 
mizer) into random-access memory banks of 
from 15 million to 16 billion eight-bit bytes per 
input/output module and whose average access 
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Figure 1-2. Maximum Configuration of the B 7700 System 



time is 23 or 40 milliseconds. 

3. Disk pack memory modules that are com- 
bined into random-access memory banks with 
a capacity for from 121 million to many bil- 
lions of eight-bit bytes of storage per input/ 
output module and whose average access time 
is 30 milliseconds. 



In addition to the 255 peripheral devices 
that may be included in the input/output sub- 
system, there is a vast network of remote ter- 
minals, remote controller, and remote comput- 
ers that can be accommodated by as many as 
1024 remote lines served by the four program- 
mable data communications processors that 
can be controlled by a single input/output 
module. Normally, each line handles a number 
of remote devices, and, naturally, systems that 
have more than one input/output module can 
have more than one data communications net- 
work. Theoretically, the maximum number of 
data communications processors that could be 
included in a B 7700 system is 28. (However, 
currently, the software; can only handle a max- 
imum of eight.) 



MINIMUM CONFIGURATION 
The smallest possible B 7700 system is com- 



posed of the central components listed below. 

Central Components Qty 

Central processor module (CPM) 1 

Input/output module (IOM) 1 

Memory module l 

Memory control module (MCM) 1 

Memory storage cabinet (MSC) 2 

Memory storage unit (MSU) 4 

Maintenance diagnostic unit (MDU) and its 1 

associated magnetic tape unit 

Operator's console l 

In addition to these central components, the 
minimum configuration must contain a disk 
file memory subsystem at least large enough 
to hold the master control program, a card 
reader, a line printer, a magnetic tape unit, 
peripheral controls, and ac power cabinets. In 
practice, other peripheral devices and their 
controls are used with this minimum 
configuration. 

Naturally, this minimum system lacks the 
redundancy and power of larger configura- 
tions. First (lacking redundancy of main-frame 
modules), this configuration does not take 
complete advantage of the fail-soft features 
possible with the B 7700 and second (because 
each memory control module controls but two 
storage units), only two-ward transfers, not 
four-word transfers, to and from memory are 
possible. 
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CHAPTER II 



SYSTEM ARCHITECTURE 



SECTION 1 
DATA REPRESENTATION 



GENERAL 

The basic information structure used in the 
B 7700 Information Processing System is the 
word. Each word contains 48 information bits, 
three tag bits, and one parity bit. (See figure 
11-1-1.) The information bits may be used to 
store character values, logical values, or nu- 
meric values. The tag bits are control bits 
which identify the type of information con- 
tained in the information field. The tag bits 
are inaccessible to normal state (user) pro- 
grams. The parity bit is used to check for cor- 
rect information transfer between the CPM or 
IOM and main memory. 
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Figure 11-1-1. Word Structure 

INTERNAL CHARACTER CODES AND 
COLLATING SEQUENCES 

Extended Binary Coded Decimal Inter- 
change Code (EBCDIC) is the primary internal 
character code of the B 7700. EBCDIC is an 
eight-bit alphanumeric code containing four 
zone bits and four numeric bits. Other internal 
codes which may be used include the American 
Standard Code for Information Interchange 
(ASCII), and the Burroughs Common Lan- 
guage Code (BCL). ASCII is the primary data 
communication code; BCL is used to interface 
with peripheral units. Numeric EBCDIC and 
BCL codes may be packed into four-bit digits 
by internal commands which delete the zones 
and compress the numeric portion of the char- 
acters. In general, characters are collated ac- 
cording to their internal binary value. Charac- 
ter codes and collating sequences are provided 
in the appendices. 



NUMBERS AND NUMBERING SYSTEMS 

The B 7700 is a digital computer; that is, val- 
ues are stored internally in binary digits (bits). 
Data displayed in registers and printed forms 
may be in octal or hexadecimal format. Gener- 
ally, we think in terms of, and manually per- 
form arithmetic with, decimal numbers. Thus, 
an understanding of all of these numbering 
systems is desirable. 

The decimal system is based on the ten dig- 
its 0, 1, 2, 3, 4, 5, 6, 7, 8, and 9, and upon the 
powers of ten. The binary system is based up- 
on the two digits and 1, and the powers of 
two. Two raised to the third power (2 3 ) is 8, the 
base of the octal system. Two raised to the 
fourth power (2 4 ) is 16, the base of the 
hexadecimal system. The set of digits for each 
number system is shown in figure II-1-2. 

The digits through 9 and the alphabetic 
characters A through F comprise the 16-char- 
acter requirement for the hexadecimal num- 
bering system. The letter A is assigned a value 
of 10. B equals 11, etc., to F, which equals 15. 
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Figure 11-1-2. Number Base Graphic Characters 

BINARY NOTATION 

Because a binary digit may have only one of 
two values, it can be represented by a flip-flop 
or a bit. A number in internal binary represen- 
tation is then a series of bits which are either 
on or off. When a bit is on (1), its position de- 
termines the value. Consider an example of 
five bits. 

The least significant bit, if on (1), has a val- 
ue of 2°, or 1; the next most significant bit to 
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Figure 11-1-3. Binary Integers 



the left of the binary point has the value of 2 1 , 
or 2; the third bit (count from right to left) has 
the value of 2 2 , or 4; etc. In this way, any inte- 
ger can be represented in binary form. Figure 
II-1-3 illustrates some integers. Fractions in 
binary are much the same as integers. Here, 
though, the powers are negative powers with 
the first power to the right of the binary point 
having the value of 2- 1 , or 1/2; the second bit 
has the value of 2- 2 , or 1/4; the third bit 2- 3 , 
or 1/8; the fourth bit, 2- 4 , or 1/16; etc. It is ap- 
parent that while some fractions are repre- 
sented correctly, others can only be 
approximated. However, the degree of error is 
very small when a sufficient number of bits 
are used. 



HEXADECIMAL AND OCTAL NOTATION 

Since binary words are cumbersome to dis- 
play, the more efficient methods of 
hexadecimal and octal notation are used. The 
hexadecimal representation of a binary word 
is obtained by dividing the bits into groups of 
four with each group assigned a successive 
power of 16. A binary-to-octal conversion is ob- 
tained by dividing the bits into groups of three 
and assigning successive powers of 8 to each 
group (figure II-1-4). 

The relationship between octal, decimal and 
hexadecimal is shown in figure II-1-5 using 
the decimal number l0| 3 |0 (equivalent to " fc5 8 
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dicates the base). 
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Figure 11-1-5. Relationship of Octal, Decimal, and 
Hexadecimal Numbers 

NUMBER CONVERSION 

BINARY TO DECIMAL CONVERSION 

INTEGRAL 

This conversion is effected by adding togeth- 
er the value of each bit that is on. In this way, 
the binary number 11010011 would be equal to: 

Ix2 7 +lx2 6 +0x2 s +lx2 4 +0x2 3 +0x2 2 +lx2 1 +lx2 = 
Ix2 7 +lx2 6 + +lx2 4 + +0 +lx2 1 +lx2°= 
128+64+16+2+1 211 10 
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Figure 11-1-4. Binary to Hexadecimal and Octal Conversion 



A second method of effecting a binary-to- 
decimal conversion is the "double dabble" 
method. In this procedure, the high-order bit 
is doubled (multiplied by 2) and then added to 
the next lower-order bit. This sum is then dou- 
bled and again added to the next lower bit. 
This process is continued until the entire bina- 
ry number has been expended (figure II-1-6A). 
The correct result is obtained after the low-or- 
der bit (units) has been added. 

FRACTIONAL 

The above process will work for integral 
numbers and for the integral part of frac- 
tional numbers, but it will not work for the 
fractional part of fractional numbers. To con- 
vert binary fractions to decimal fractions, divi- 
sion is used. As was previously stated, the bits 
to the right of the binary point have the de- 
creasing values of 2- 1 , 2- 2 , 2- 3 , 2- 4 , etc., or, as 
fractions 1/2, 1/4, 1/8, 1/16, etc., respectively. 

To find the decimal equivalent of a binary 
fraction, the lowest order significant bit is tak- 
en as the integer 1 and divided by 2. The next 
higher-order bit is then added into the units 
position of the resulting quotient, and the divi- 
sion is repeated. This is repeated until the bi- 
nary point is reached. The result is complete 
when the bit to the immediate right of the bi- 
nary point has been added into the units posi- 
tion and the result divided by 2. This process 
is shown in figure II-1-6B. 



DECIMAL TO BINARY CONVERSION 

INTEGRAL 

Decimal to binary conversion may be ef- 
fected in several ways. If the powers of 2 are 
known, then the binary equivalent can be 
found by subtracting from the number the 
largest power of 2, which is smaller than the 
decimal number, and then recording a bit for 
that power of two. The largest power of 2, 
which is smaller than the result of the preced- 
ing subtraction, is then found, subtracted, and 
the corresponding binary bit recorded. In ef- 
fect, this is the reverse of the first method of 
converting from binary to decimal. 

A second method of conversion is done by 
successive division. The decimal number to be 
converted is divided by 2 and the quotient and 
remainder are noted. The remainder will al- 
ways be either or 1. Then the quotient is di- 
vided by 2, resulting in another quotient and 
remainder. This is repeated until the quotient 
is 0. The remainder, resulting from the first 
division, is the low order bit; the last remain- 
der is the high order bit. This process is valid 
for the integral part of a number (figure II-l- 
7A). 

FRACTIONAL 

The fractional part of a number may be con- 
verted in a method similar to the preceding 
method of division. The fraction is multiplied 
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Figure 11-1-6. Binary to Decimal Conversion 
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Figure 11-1-7. Decimal to Binary Conversion 



by 2 and, if the result is greater than 1, the 1 
is recorded in the binary string as a 1 bit. If 
the product remains less than 1, the binary bit 
is 0. The fractional part of the product is car- 
ried down and again multiplied by 2. This is 
repeated until the fractional part is equal to 0, 
or the required degree of accuracy is attained. 
This process is shown in figure II-1-7B. 

DECIMAL TO OCTAL CONVERSION 

INTEGRAL 

To convert a decimal number to its octal 
form, the powers of eight may be used. An- 
other method is to divide the number by eight. 



The remainder is the low-order octal digit. The 
quotient is then again divided by eight, and 
the remainder resulting is the next higher-or- 
der octal digit. This process is repeated until 
the quotient is zero. This method is used for 
the integral part of numbers (figure II-1-8A). 

FRACTIONAL 

When a fractional part of the number is to 
be converted, multiplication is used. Here, the 
fraction is multiplied by eight and the integral 
portion formed is the first octal digit to the 
right of the octal point. This process is re- 
peated until either the fraction is zero, or the 
desired degree of accuracy is attained. This 
conversion is shown in figure II-1-8B. 
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Figure 11-1-8. Decimal to Octal Conversion 
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Figure 11-1-9. Powers of 8 



OCTAL TO DECIMAL CONVERSION 

OCTADE 

In octal to decimal or decimal to octal con- 
versions, if the powers of 8 are known, then 
the procedure is much the same as the corre- 
sponding subtraction method of binary. The 
difference is the digital multiplier which will 
have a value of from through 7 in octal. 
Each octal digit will be referred to as an oc- 
tade. The values of the octades are shown in 
figure 1 1-1-9. 

INTEGRAL 

On the conversion from octal to decimal, a 
method very similar to "double dabble" may 
be used. Here, the higher-order octade is mul- 
tiplied by 8 and then added to the next lower 
octade. This sum is then multiplied by 8 and 
again added to the next lower octade. This is 
continued until the first octade to the left of 
the octal point is reached. After the units oc- 
tade has been added, the result should be com- 
plete (figure II-1-10A). 

FRACTIONAL 

The above method is valid for the integral 
part of a number, but for the fractional part 
of a number, the following must be used. The 
lowest order octade is considered to be an inte- 
ger. As such, it is divided by 8. The next high- 
er octade is then added to this quotient in the 
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Figure 11-1-10. Octal to Decimal Conversion 
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units position and the sum is again divided by 
8. This continues until the first octade to the 
right of the octal point has been added and the 
result divided by 8. (See figure II-1-10B.) 

DECIMAL TO HEXADECIMAL CONVERSION 

To convert an integral or a fractional 
decimal number to its hexadecimal form, the 
powers of 16 may be used. Methods similar to 
those used for conversion to octal representa- 
tion may also be used, with the multiplication 
or division being by 16 rather than eight; how- 
ever, such methods are very cumbersome. The 
simplest method is to convert the decimal 
number to a binary number as described ear- 
lier, and then convert the binary number to its 
hexadecimal representation (each four binary 
digits are used to form one hexadecimal digit). 

HEXADECIMAL TO DECIMAL CONVERSION 

The simplest method for converting integral 
or fractional hexadecimal numbers to their 
decimal equivalent is to first convert the 
hexadecimal number to its binary equivalent 
(each hexadecimal digit is used to from four 
binary digits) and then convert the resulting 
binary number to its decimal representation 
as described earlier. 

OPERAND FORMATS 

Operands are the words of information that 
are worked with when processing. An operand 
may be used to store numeric values (a numer- 
ic operand), logical values (a logical operand), 
or character values (a string operand). Most 
operands are one word in length, and are iden- 
tified by a tag field of zero. Double precision 
operands, which are used to store numbers in 
which many significant digits of accuracy are 
needed, are two words in length and are iden- 
tified by a tag field of two. Thus, the tag field 
of an operand indicates the size of the operand 
(one or two words). 



NUMERIC OPERANDS 

Numeric operands are used to store numeric 
values (numbers) in floating point format. A 
numeric operand may be single or double pre- 
cision. 

When the tag bits of a memory word (bits 50, 
49, 48) are (000), they denote a single-preci- 
sion operand. When the tag bits are 2 (010), 
i.e., bit 49 set, they denote a double precision 
operand. 

SINGLE PRECISION OPERANDS 

All numeric operands are expressed in float- 
ing point form, where each numeric operand 
has both a mantissa and an exponent. This 



form may be related to power of ten notation 
where 13297. is the mantissa and -3, the expo- 
nent in a representation of the number 13.297 
(13297. x 10- 3 ). The mantissa of a single preci- 
sion operand is comprised of 39 bits which 
make up 13 octades. The mantissa of a single 
precision numeric operand is considered to be 
an integer and is treated as such; i.e., the bi- 
nary point is considered to be to the right of 
the least significant octade. The exponent of 
the number is represented by 6 bits (bits 44 
through 39) which form two octades. Bit num- 
ber 45 is the sign of the exponent. When 45 is 
off, the exponent is positive; when on, 
negative. Bit 46 is the sign of the mantissa, 
which is the overall sign of the operand. 

The structure of a single precision operand 
is shown in figure II-l-ll. Because the expo- 
nent is an octal scale factor, the single preci- 
sion operand is shown in both hexadecimal 
and octal representation. 

EXPONENT FIELD 

The exponent is a binary number which, 
with its sign, is an octal scale factor for the 
mantissa. That is, the binary point in the man- 
tissa must be shifted left three binary places 
(the mantissa must be shifted right three bi- 
nary places) for each increase by one in the 
value of the exponent. The exponent is used 
for automatic scaling of operands when arith- 
metic, comparison and integer operations are 
being performed. The range of the exponent is 
from +63 to -63 for single-precision operands. 

SINGLE PRECISION OPERAND (OCTAL REPRESENTATION) 
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Figure 11-1-11. Single Precision Operand 
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MANTISSA FIELD 

The mantissa is the significant part of the 
operand. The magnitude of the operand is ob- 
tained by multiplying the value contained in 
the mantissa by eight raised to the value of 
the exponent sign and exponent as follows: 

V =± M x 8± E 
where: 

V = Value of number 

± M = Mantissa with sign 
± E = Exponent with sign 

The order of number magnitude in the 39 bit 
mantissa, as decimal numbers and powers of 
base 16, 8, and 2 is shown in figure II-1-12. 



DOUBLE PRECISION OPERANDS 

Double precision operands are identified by a 
tag field of two, indicating that the operand is 
one of a pair of two words (figure II-1-13). 

The first word of the double precision oper- 
and is identical to the single precision oper- 
and. 



The integral part of the mantissa is con- 
tained in the mantissa field of the first word. 
The fractional part of the mantissa is con- 
tained in the mantissa extension field of the 
second word. 

The 15-bit exponent of a double precision op- 
erand is formed by the concatenation of the 
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FIRST 39 BITS SET. (MAXIMUM INTEGER VALUE ALLOWED) 

Figure 11-1-12. Order of Magnitude Chart 
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FIRST WORD 



DOUBLE PRECISION OPERAND (OCTAL REPRESENTATION) 
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Figure 11-1-13. Double-Precision Operand 
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Figure 11-1-14. Logical Operand 
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exponent extension with the exponent. The ex- 
ponent extension is more significant than the 
exponent. 

NUMBER RANGES AND NORMALIZATION 

To add and subtract two numeric operands 
on the B 7700, the exponents of the two oper- 
ands must be equal. The B 7700 equalizes the 
exponents of the two operands automatically; 
this equalization may require that one of the 
operands be "normalized." Normalization oc- 
curs if the exponent difference of the two op- 
erands is greater than the number of leading 
zero (octal) digits in the mantissa of the oper- 
and with the larger exponent. In such cases, 
the larger operand is normalized, and the 
mantissa of the smaller operand is then 
shifted right until the exponents are equal. 



A normalized number is a number which has 
the smallest exponent with which the number 
can be expressed without losing the most sig- 
nificant digit of the number. A number is nor- 
malized by shifting the mantissa to the left, 
(moving the binary point right) in three-bit in- 
crements until the number of leading zeroes in 
the mantissa is less than three. For each 
three-bit shift to the left (of the mantissa), the 
exponent is decreased by one. 

Because of automatic normalization by the 
CPM, the range of numbers which are useable 
on the B 7700 includes both normalized and 
unnormalized numbers. In general, normalized 
numbers are those which the system may use 
for arithmetic, and unnormalized numbers are 
those which the system may store. 



The largest and smallest numbers representable as normalized and unnormalized operands 
are: 

549755813887io 
or 

8 13 -1 

0007777777777777 

4.31359146673xl0 68 
or 

(8 13 -l)x8 63 

0777777777777777 

302231454903657293676543 
or 

8 2e -l 
(first word) 0157777777777777 



The largest single precision integer 



The largest single precision number 



The largest double precision integer 



(second word) 0007777777777777 
The largest double precision number 1.948828382050280791124469xl0 29G03 

or 

(1_S_26) x g32780 

(first word) 0777777777777777 
(second word) 7777777777777777 



The smallest positive unnormalized single 
precision number 



The smallest positive normalized single 
precision number 



The smallest positive normalized double 
precision number 



1.27447352891xl0- 57 



1770000000000001 
8.7581154020xl0- 47 



1771000000000000 
1.93854585713758583355640xl0- 29581 



decimal 
octal 

lecimal 
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lecimal 



-j decii 
j octa 

} 



octal 



decimal 



i decims 
' octal 



decimal 

al 



\ decn 
' octa 

\ decimi 
) octal 



decimal 



decimal 



octal 



(first word) 1771000000000000 
(second word) 7770000000000000 

The number sets are symmetrical with respect to zero. The negative number corresponding 
to any valid positive number may also be expressed. From the ranges above, one can see that 
a single precision integer must always have an exponent of zero. 
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LOGICAL OPERANDS 

Logical operands (figure II-1-14) have one of 
two values: true (on) or false (off). Logical val- 
ues are the result of Boolean operations or re- 
lational operations. Relational operators gen- 
erate a logical value as the result of an alge- 
braic comparison of two arithmetic expres- 
sions. Bit contains the logical value. Rela- 
tional operators set bit 0, where conditional 
operators use bit for the decision. 

NOTE 
Logical operators (LAND, LOR, 
LNOT, and LEQV) cause a logical 
operation to be performed on each 
bit of the two operands and the re- 
sults of these operations (48 single 
precision values or 96 double preci- 
sion values) are left in the top-of- 
stack operand. Logical operators 
may operate on logical, string, or 
numeric operands. 

STRING OPERANDS 

A string operand is a single word operand 
(identified by a tag ol f zero) which is used to 
store characters. Character representation 
may be 8-bit (EBCDIC), 7-bit (USASCII), 6-bit 
(BCL), or 4-bit (packed BCD) characters. Gen- 
erally, a string of characters is stored in one 
or more string operands in memory as an ar- 
ray or table. Such arrays or tables are ad- 
dressed by means of string descriptors. The 
format of string operands for storage of 8-bit, 
7-bit, 6-bit, and 4-bit characters is shown in 
figure II-1-15. 

String operands may also be used to store 
signed numeric characters in 8-bit, 6-bit, and 
4-bit formats. Each string operand can store 
one signed numeric number consisting of six 8- 
bit characters, eight 6 -bit characters, or 11 4- 
bit characters. Eight-bit and 6-bit characters 
are divided into a zone portion and a number 
portion. The number portion consists of the 
four least significant bits of each character; 
the remaining bits form the zone. When 8-bit 
or 6-bit signed numeric characters are stored 
in a string operand, the sign of the characters 
is stored in the zone bits of the least 
significant character. When 4-bit signed nu- 
meric characters are stored in a string oper- 
and, the sign of the characters is stored as the 
most significant character of the operand. Ta- 
ble 11-1-1 shows the bit configurations for neg- 
ative and positive signs in 8-bit, 6-bit, and 4-bit 
formats. Figure II-1-16 illustrates the manner 
in which a signed number (-41259) is stored in 
8-bit bit, 6-bit, and 4-bit code. 
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Figure 11-1-15. String Operands 
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8-BIT BYTES (EBCDIC CODE) 
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6-BIT CHARACTERS (BCL CODE) 
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Figure 11-1-16. Use of String Operand to Store Signed Number (-4259) 



Table 11-1-1. Sign Configurations Of String Operands 



Size Sign Location 

8-bit Zone, least significant 
character 

6-bit Zone, least significant 
character 

4-bit Most significant digit 



Negative Positive 

1101 Any bit configuration other than the negative bit 
configurations 
10 Any bit configuration other than the negative bit 
configurations 

1101 Any bit configuration other than the negative bit 
configurations 



2-12 



SECTION 2 



POLISH NOTATION AND STACK 



GENERAL 

To facilitate the understanding of the 
B 7700 stack concept, a method of 
mathematical notation known as Polish nota- 
tion must be understood. A problem that ex- 
ists with most forms of mathematical notation 
is clarifying the boundaries of specific terms. 
This has been eliminated with the use of pa- 
rentheses, brackets, and braces. However, with 
a complex equation, it becomes necessary to 
duplicate the use of the few types of delimit- 
ers that exist. It might be noted that it is com- 
mon to encounter mathematical equations 
such as Y = 5Z + 7/2Z and Y = (5Z + 7)2Z. 
Two equations express different functions of 
Z, but one could easily be used when the other 
was intended. From this it can be seen that an 
error in notation can change the whole prob- 
lem, because the parentheses have definite 
meaning. 

Polish notation is an arithmetical or logical 
notational system using only operands and op- 
erators arranged in a sequence or string which 
eliminates the necessity of factor boundaries. 
The B 7700 compilers translate source state- 
ments to Polish strings, and convert these Po- 



lish strings to a series of machine instructions 
(program operators). 

POLISH NOTATION 

The essential difference between Polish no- 
tation and conventional notation is that 
operators are written to the right of operands 
instead of between them. For example, the 
conventional B + C would be written B C + in 
Polish notation. Looking at the example, A = 
7 (B + C), it would be written in Polish nota- 
tion as follows: 

A7BC+*= 

Any expression written in Polish notation is 
called a Polish string. In order to fully under- 
stand this concept, the rule for evaluating a 
Polish string should be known. 

GENERAL RULES FOR GENERATION OF 
POLISH STRING 

Figure II-2-1 is a flow chart for generation 
of a Polish string. In general, the rules for 
generation of a Polish string may be stated as 
follows. If the source of expression is: 



Name 



A Variable 



An Operator 
-Separator 

-Arithmetic or Boolean operator and last entered 
delimiter list symbol was: 

a. an operator of lower priority. 

b. a left bracket " [ " or paren "(". 

c. a separator. 

cl. nothing (delimiter list empty). 

-An Arithmetic or Boolean operator and last entered 
delimiter list symbol was: an operator of priority equal 
to or greater than the symbol in the source. 

-A right bracket " 1 " or parenthesis ")" 



Action 

Place variable in string being built and examine next 
symbol. 

Place in delimiter list and examine next symbol. 

Place operator in the delimiter list and examine next 
source symbol. 



Remove the operator from the delimiter list and place 
in the string being built. Then compare the next symbol 
in the delimiter list against the source expression 
symbol. 

Pull out from delimiter list or until corresponding left 
bracket or parenthesis. 
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Figure 11-2-1. Polish Notation Flow Chart 



EVALUATING POLISH STRING 

The following procedure may be used to 
evaluate a Polish string. 

a. Scan the string from left to right. 

b. Remember the operands and the order in 
which they occur. 

c. When an operator is encountered do the 
following: 

1) Take the two operands which were last 
encountered. 

2) Operate upon them according to the 
type of operator encountered. 

3) Eliminate these two operands from fur- 
ther consideration. 

4) Remember the result of (2) and consider 
it as the last operand encountered. 

Following this procedure through the Polish 
string A7BC+* = would evaluate to A as- 
suming the value 7 (B + C) (figure 1 1-2-2). 

NOTE 
Because replacement operators 
vary depending upon the language 
used, 4— , =, and := may be used 
interchangeably in discussing Po- 
lish strings. 



PROGRAM CODE STRING 

When a program is compiled, the source lan- 
guage statements are converted into a string 
of machine language operators. These 
operators are assembled into a Polish notation 
string and are referred to as the program code 
string. Each machine instruction in the string 
normally consists of one to three 8-bit sylla- 
bles. The instructions are packed consecutively 
into program words. (See figure II-2-3.) An ar- 
ray of program words, which can be any 
length, is called a program code segment. The 
compiler usually divides the generated code 
string into two or more program segments. 
The number of segments depend on the struc- 
ture of the source program. Program segments 
are normally stored on disk files. When a pro- 
gram is executed, program segments are made 
present in memory as needed. Because pro- 
gram segments are not modified during execu- 
tion;, a single copy of a program segment in 
memory may be used for several concurrent 
executions of the same program; thus, the pro- 
gram code string is often described as "re-en- 
trant". 



tep 


Symbol 

Being 
Examined 


Symbol 
Type 


a 


B 


Operand 


b 


C 


Operand 


c 


+ 


Add 
Operator 


d 


7 


Operand 


e 


X 


Multiply 
Operator 


f 


A 


Operand 


g 


= 


Replace 
Operator 



Operands Being Remembered and Their Order of 
Occurrence (1 or 2) Before Operation 

1 B 



Operation Results 

Taking Place Operation 



2 


C 




1 


B 




1 


(B 


+ C) 


2 


7 




1 


(B 


+ C) 


1 


7(B 


+ C) 


2i 
1 


7(B 


+ C) 



B + C 



(B + C) 



7 x (B + C) 7 x (B + C) 



A 4- 7(B + C) A = 7(B + C) 



Figure 11-2-2. Evaluation of Polish String A7BC+* = 



COMPILATION USING POLISH NOTATION 

Polish notation is used as the base for the 
B 7700 ALGOL compilation algorithm. An 
ALGOL arithmetic or Boolean expression or 
assignment statement may be translated to 
Polish notation in much the same way as the 
arithmetic (or algebraic) expression that al- 
ready has been considered. In compiler trans- 
lation, the source expression is examined one 
symbol at a time with a left to right scan and 
is combined into logical entities. As each 
logical entity is examined, a specific procedure 
is followed so that the Polish notation expres- 
sion is constructed in its finalized form with 
one scan of the source expression. 



For each program segment, there is a single 
segment descriptor, which defines the length 
and location of the program segment. The seg- 
ment descriptors are stored in a special stack 
known as the segment dictionary. 

Each job is associated with an unique job 
stack and with a segmented dictionary stack 
which may be shared by several jobs. (In addi- 
tion, the MCP has its own stack and segment 
dictionary.) Within the job stack, a Program 
Control Word is provided for each point of en- 
try into a segment of code. The PCW provides 
an index, not only into the segment dictionary 
to locate the proper segment descriptor, but 
also into the program segment itself to locate 
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Tag field. Value of three indicates 
that this word is non-modifiable 
(except by Overwrite operators). 
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Figure 11-2-3. Program Word 

the proper program word and syllable. The for- 
mats of the segment descriptor and the PCW 
are described in detail in section 3 of this 
chapter. 

STACK CONCEPTS 

The constants and variables of a program 
are assigned locations within the "stack" of 
the program when it is compiled. The stack 
can be thought of as analogous to a physical 
stack where the last item placed on the stack 
is the top of the stack. When items are re- 
moved (one at a time) from the stack, the item 
on the top of the stack is the first item to be 
removed. The item at the bottom of the stack 
remains at the bottom of the stack until all 
other items have been removed from the 
stack. The stack not only provides an easily 
manageable means for keeping a dynamic hi- 
story of the program as it is being processed, 
but also lends itself to the use of program code 
strings based on Polish notation. 

GENERAL 

A job is activated by having a processor as- 
sign to the job stack. Two top-of-stack loca- 
tions (A and B) are linked to the job's stack 
(figure 1 1-2-4). This linkage is established by 
the stack-pointer register (S), which contains 
the memory address of the last word placed in 



the stack. The two top-of-stack locations (A 
and B) extend the stack to provide quick ac- 
cess for data manipulation. 

Data are brought into the stack through the 
top-of-stack locations in such a manner that 
the last operand placed into the stack is the 
first to be extracted. Total capacity of the top- 
of-stack locations (A and B) is two operands. 
Loading a third operand into the top-of-stack 
locations causes the first operand to be pushed 
from the top-of-stack locations into the stack. 
The stack-pointer register (S) is incremented 
by 1 before a word is placed into the stack and 
is decremented by 1 after a word is withdrawn 
from the stack and placed in the Top-of-Stack 
locations. As a result, the S register continual- 
ly points to the last word placed into the job's 
stack. 

BASE AND LIMIT OF STACK 

A job's stack is bounded, for memory protec- 
tion, by two registers: the Base-of-Stack regis- 
ter (BOSR) and the Limit-of-Stack register 
(LOSR). The contents of BOSR define the base 
of the stack, and the contents of LOSR define 
the upper limit of the stack. The job is inter- 
rupted if the S register is set to the value, con- 
tained in either LOSR or BOSR. 
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BI-DIRECTIONAL DATA FLOW IN THE STACK 

The contents of the top-of -stack locations are 
maintained automatically by the processor to 
meet the requirements of the current 
operator. If the current operator requires data 
transfer into the stack, the top-of-stack loca- 
tions receive the incoming data, and the sur- 
plus contents, if any, of the top-of-stack loca- 
tions, are pushed into the stack. Words are 
brought out of the stack into the top-of-stack 
locations. These words are used by operators 
which require the presence of data in the top- 
of-stack locations. These operators, however, 
do not explicitly move data into the stack. 

DOUBLE PRECISION STACK OPERATION 

Each top-of-stack location (A and B) can ac- 
commodate two memory words. For single pre- 
cision operations, location A will contain one 
single precision operand and location B will 
contain the other single precision operand. 
However, calling a double precision operand 
into either top-of-stack location (A or B) will 
cause both halves of the double precision oper- 
and to be loaded into the A or B location. The 
first word is loaded into the top-of-stack loca- 
tion and its tag bits are checked. If the value 
of the tag bits indicates double precision, the 
second half of the operand is loaded into the 
second half of the top-of-stack location. 

Double precision operands revert to single 
words when they are pushed down into the 
stack (the most significant half of the operand 
is pushed down first). The process is reversed 
when a double precision operand is returned 
from the stack to the top-of-stack locations. 
That is, the least significant half of the double 
precision operand is popped up first and the 
tag is discovered to have a value of two, caus- 
ing the most significant half of the operand to 
also be popped into the top-of-stack. 

HARDWARE IMPLEMENTATION 

The B 7700 stack implementation includes a 
32-word stack buffer, which permits a portion 
of an active stack to be contained in IC 
memory locations within the CPM. This stack 
buffer (see figure II-2-5) may contain informa- 
tion which has not yet been written to core 
memory, as well as copies of words which are 
resident in core memory. The stack buffer per- 
mits a portion of the stack to be held local 
within the CPM, to provide quick access for 
stack manipulation by the execution unit of 
the CPM. 

In addition to the portion of the stack held 
local in the stack buffer, certain other data 
from the stack may be contained in a local 
memory within the CPM. This local memory, 



the associative memory, is used to capture 
data fetched by program unit look ahead 
which is not resident in the stack buffer. 

Although an active stack may be contained 
partly in the stack buffer within the CPM and 
partly in core memory, the stack buffer is 
purged whenever the stack becomes inactive 
(when a move-to-stack operation takes place). 
This purging of the stack buffer causes the 
unique data within the stack buffer to be cop- 
ied to core memory. Thus, for practical pur- 
poses, this section discusses the stack as if it 
exists solely within core memory. A detailed 
description of the stack buffer and the associa- 
tive memory may be found in chapter III. 

DYNAMIC PROGRAM HISTORY 

One very important aspect of the B 7700 is 
the retention of the dynamic history for the 
program being processed. Two lists of program 
history are maintained in the B 7700 stack, 
the addressing environment list and the stack 
history list. 

Both of these lists are dynamic, varying as 
the job proceeds along different program 
paths with varying sets of data. The two lists 
grow and contract in accordance with the pro- 
cedural depth of the program. Both of these 
lists are generated automatically by the 
B 7700 hardware. Before further stack discus- 
sion can be considered, addressing history and 
stack history must be discussed. 

ADDRESSING HISTORY 

The B 7700 CPM provides two methods for 
addressing data. Direct addressing is provided 
by descriptors, which contain the address (core 
or disk) of the data. Descriptors are used to 
address data which are located outside of the 
stack area of the job. Relative addressing is 
provided by the Indirect Reference Word 
(IRW) and the Stuffed Indirect Reference 
Word (SIRW). The IRW and SIRW address 
components are both relative address compo- 
nents. The IRW addresses within the immedi- 
ate environment of the job relative to one of 
32 CPM display registers. The SIRW addresses 
beyond the immediate environment of the cur- 
rent procedure, the addressing being relative 
to the base of some job stack. Addressing 
across stacks is accomplished with an SIRW. 

DIRECT ADDRESSING 

In general, the descriptor describes and lo- 
cates data associated with a given job. String 
descriptors and data descriptors are used to 
fetch data to the stack or to store data from 
the stack into an array located outside the 



2-17 



MAIN MEMORY 



TOP-OF- STACK LOCATIONS 



INPUT/OUTPUT 

PATH OF DATA 

TO/FROM STACK 



LOSR 



J 



TOS WORD 



STACK 
BUFFER 



STACK 

BUFFER 

AREA 

CURRENTLY 

IN USE 



1 



STACK 

MEMORY 

AREA 



S REG. 



STACK 

AREA 

ASSIGNED 

TO 
PROGRAM 



STACK 

AREA 

CURRENTLY 

IN USE 



ip n 



BOSR 



Figure 11-2-5. Stack Buffer and Stack Memory Area 
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stack area of the job. The address contained in 
one of these descriptors is the absolute ad- 
dress of an array in either system main 
memory or in the backup disk file, as indicated 
by the setting of a single bit called the pres- 
ence bit. Another bit, called the presence bit. 
Another bit, called the double-precision bit, is 
used to identify the referenced data as single 
precision or double precision. The formats of 
string and data descriptors, and detailed dis- 
cussions of each, are presented in section 3 of 
this chapter. 

RELATIVE-ADDRESSING 

Analyzing the structure of an ALGOL pro- 
gram results in a better understanding of the 
relative-addressing procedures used in the 
B 7700 stack. The addressing environment of 
an ALGOL procedure is established 
automatically as the program is structured by 
the programmer and is referred to as the lexi- 
cographical ordering of the procedural blocks. 
At compile time, the lexicographical ordering 
is used to form address couples. An address 
couDle consists of two items: 

1. The lexicographical addressing level (LL) 
of the variable, 

2. An index value (I) used to locate the spe- 
cific variable within its addressing level. 



The lexicographical ordering of the program 
remains static as the program is executed, 
thereby allowing variables to be referenced 
via address couples as the program is 
executed. 

The lexicographical structure of a very sim- 
ple ALGOL program is illustrated in figure II- 
2-6. When executed, this program would call 
procedure C (LL=3) from the outer block of 
the program (LL=2), and, in turn, procedure C 
would call procedure D (LL=4). The stack 
structure is illustrated as it would exist as 
procedure D was being executed. It can be 
seen that, as the outer block of the program 
was entered, and again as each procedure was 
entered, a Mark Stack Control Word (MSCW) 
was placed in the stack. The MSCW (described 
in detail in section 3 of this chapter) denotes 
the base of each lexicographical addressing 
level. 

DISPLAY REGISTERS 

Each MSCW provides a point in the stack 
relative to which the variables for the associ- 
ated addressing level may be referenced. The 
B 7700 CPM unit contains 32 display registers 
(D [ ] through D for [ 31 ] ).As shown, the 
base of each addressing level is addressed by 



BEGIN 
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REAL V2; 

PROCEDURE C; 

BEGIN - 
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LL ■ 

LL : 



3, I = 2 
3,1=3 



FIEAL V5; 
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Figure 11-2-6. ALGOL Program With Lexicographical Structure and Related Stack Structure 
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one of these registers. The local variables of 
the outer block or of the procedures are ad- 
dressed relative to the D registers. The D reg- 
isters are updated at each procedure entry or 
exit. 
ABSOLUTE ADDRESS CONVERSION 

Each variable is indirectly addressed by an 
address couple containing a lexicographical 
level and an index value. The address couple is 
converted into an absolute memory address 
when the variable is referenced. The lexicogra- 
phical level portion of the address couple se- 
lects the D register which contains the abso- 
lute memory address of the MSCW for the en- 
vironment (lexicographical level) in which the 
variable is located. The index value of the ad- 
dress couple is added to the contents of the D 
register to generate the absolute memory ad- 
dress of the desired variable. 

ADDRESSING ENVIRONMENT 

Thus far we have considered a very simple 
program in which each procedure has a differ- 
ent lexicographical addressing level. General- 
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BEGIN - 
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END; 



LL= 2, I = 5 
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ly, however, many procedures of a program 
may have the same lexicographical addressing 
level; however, no two procedures of a pro- 
gram may have the same addressing environ- 
ment. Consider the more advanced exemplary 
program shown in figure 1 1-2-7. 

This program consists of an outer block 
(LL=2), two procedures which have a lexico- 
graphical addressing level of three (procedures 
A and C), and two procedures which have a le- 
xicographical level of four (procedures B and 
D). The addressing environment of the pro- 
gram is maintained automatically by linking 
the MSCWs together in accordance with the le- 
xicographical structure of the program. This 
linkage is composed of the stack number 
(STACK NO.) and displacement (DISP) fields 
of the MSCW, and is inserted into the MSCW 
when the procedure is entered. A tree-struc- 
tured addressing environment list is formed 
by linking the MSCW to the MSCW at the pre- 
ceding lexicographical level to the procedure 
being entered. This tree-structured list indi- 
cates the addressing environment of the proce- 
dures. 
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Figure 11-2-7. More Advanced ALGOL Program 
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Comparing the addressing tree in figure II- 
2-8 with the exemplary program, one can see 
that when procedure B is being executed, the 
addressing environment includes only the var- 
iables in procedures B and A and the outer 
block; variables declared in procedure C and D 
are not addressable by procedure B. Thus, one 
can see that the address couples assigned to 
the variables in a program need not be unique. 
This is true because if there is no procedure 
which can address both of any two variables, 
then the two variables may have identical ad- 
dress couples. This addressing scheme is prac- 
tical because two variables which have the 
same address couples will be contained within 
two different addressing environments. 
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tered, its parameters and local variables are 
entered in the stack following the MSCW. 
When the procedure is executed its 
parameters and local variables are referenced 
by addressing relative to the MSCW. 
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Figure 11-2-8. Addressing Environment Tree of 
ALGOL Program 

ADDRESSING ENVIRONMENT LIST 

There is a unique set of MSCWs which the D 
registers must address during the execution of 
any particular procedure. The D registers 
must be changed, upon procedure entry or ex- 
it, to address the correct MSCWs. The process 
of changing the D registers is referred to as 
display update. The list of MSCWs which the D 
registers address is is the addressing environ- 
ment list, and the areas of the stack which can 
be addressed relative to the settings of the D 
registers are the addressing environment. 

STACK HISTORY 

The B 7700 stack provides an easily manage- 
able means for keeping line control informa- 
tion (program history) necessary for procedure 
entry and exit. The stack history list is a list 
of Mark Stack Control Words, linked together 
by their DF fields (figure II-2-9). 

An MSCW is inserted into the stack as a pro- 
cedure is entered and is removed as that pro- 
cedure is exited. Therefore, the stack history 
list grows and contracts with the procedural 
depth of the program. Mark Stack Control 
Words identify the portion of the stack related 
to each procedure. When the procedure is en- 



Figure 11-2-9. Stack History List 

Each MSCW is linked to the prior MSCW 
through the contents of its DF field in order to 
identify the point in the stack where the prior 
procedure began. When a procedure is exited, 
its portion of the stack is discarded. This ac- 
tion is achieved by setting the stack-pointer 
register (S) to address the memory location 
preceding the most recent MSCW (figure II-2- 
10). This topmost MSCW, addressed by another 
register (F), is deleted from the stack-history 
list by changing F to address the prior MSCW, 
placing this MSCW at the head of the stack hi- 
story. 

SIMPLE STACK OPERATION 

All program information must be in the sys- 
tem before it can be used. Input areas are allo- 
cated for information entering the system and 
output areas are set aside for information 
exiting the system; array and table areas are 
also allocated to store certain types of data. 
Thus data is stored in several different areas: 
the input/output areas, data tables (arrays), 
and the stack. Since all word is done in the 
top-of-stack locations, all information or data 
is transferred to the top-of-stack locations and 
the stack itself. 

At this point, an ALGOL assignment state- 
ment and the Polish notation equivalent will 
be related to the stack concept of operation. 
The example is Z:=Y + 2x(W+V), where : = 
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means "is replaced by." In terms of a comput- 
er program, this assignment statement indi- 
cates that the value resulting from the 
evaluation of the arithmetic expression is to 
be stored in the location representing the 
variable Z. 

When Z:=Y + 2x(W+V) is translated to Po- 
lish notation, the result is ZY2WV+ x +:=. 
Each element of the example expression 
causes a certain type of syllable to be included 
in the machine language program when the 
source problem is compiled. The following is a 
detailed description of each element of the ex- 
ample, the type of syllable compiled, and the 
resulting operation (see figure II-2-11 and ta- 
ble II-2-1). 

In the example statement, Z is to be the re- 
cipient of a value, so the address of Z must be 
placed in the stack. This is accomplished by a 
Name Call (NAMC) syllable which places an 
Indirect Reference Word (IRW) in the stack. 
The IRW contains the address of Z in the form 
of an "address couple" that references the 
memory location reserved in the stack for the 
variable Z. 

Since Y is to be added to a quantity, Y is 
brought into the top of the stack as an oper- 
and. This is accomplished with a Value Call 
(VALC) syllable that references Y. The value 2 
is then brought to the stack, with an eight-bit 
literal syllable (LT8). Since W and V are to be 
added, the respective variables are brought to 
the stack with Value Call syllables. The ADD 



operator adds the two top operands and places 
the sum in the top of stack. This example as- 
sumes, for simplicity, single-precision operands 
not requiring use of additional top-of-stack lo- 
cations which are used in double-precision op- 
erations. 

The multiply operator (MULT) is the next 
symbol encountered in the Polish string; when 
executed, it places the product "2x(W+V)" in 
the top of the stack. The next symbol, ADD, 
when executed, leaves the final result 
"Y+2x(W+V)" in the top of the stack. 

The store syllable (STOD) completes the 
execution of the statement Z:=Y + 2x(W+V). 
The store operation examines the two top-of- 
stack operands looking for an IRW or Data De- 
scriptor. In this example, the IRW addresses 
the location where the computed value of Z is 
to be stored. The stack is empty at the comple- 
tion of this statement. 



Thus, the Polish string ZY2WV + x+: = 
used to produce the following code string: 



is 



NAMC (Z) 
VALC (Y) 
LT8 2 
VALC (W) 
VALC (V) 
ADD 
MULT 
ADD 
STOD 

When this code string is executed on the 
B 7700, the value of the expression 
Y+2x(W+V) is stored in the stack location re- 
served for the variable Z. 

INTERRUPT HANDLING 

In the B 7700, hardware interrupts are 
treated as hardware-originated procedure 
calls. When the hardware detects an interrupt 
condition, the CPM causes a MSCW to be 
placed in the stack, then places in the stack an 
IRW addressing the interrupt handling proce- 
dure, places two parameters in the stack to 
identify and describe the interrupt condition, 
and then causes the interrupt handling proce- 
dure to be entered. When the interrupt han- 
dling procedure is entered, the D registers are 
updated to make all legitimate variables ad- 
dressable. Similarly, upon return from the in- 
terrupt handling procedure, the D registers 
are again updated to make all of the variables 
of the former procedure addressable again. A 
detailed description of interrupt handling is 
provided in chapter III. 
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Figure 11-2-11. Stack Operation 
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Table 11-2-1. Description of Stack Operation 

Function of Syllable During Running of the Program 



Stack location of program variables illustrated. 

Build an indirect reference word that contains the address of Z 
and place it in the top of the stack. 

Place the value of Y in the top of the stack. 

Place a 2 in the top of the stack. 

Place the value of W in the top of the stack. 

Place the value of V in the top of the stack. 

Add the two top words in the stack and place the result in the 
A location as the top of the stack operand. 

Multiply the two top-of-stack operands. The product is left in 
the A location as the top of the stack operand. 

Add the two top words in the stack and leave the result in the 
A location as the top of the stack operand. 

Store an item into memory. The address in which to store is 
indicated by an indirect reference word or a data descriptor. 
The address can be above or below the item stored. 



MULTIPLE STACKS AND RE-ENTRANT CODE 

The B 7700 stack mechanism provides a fa- 
cility for handling several active stacks, which 
are organized in a tree structure. The trunk of 
this tree structure is a stack containing MCP 
global quantities. 

LEVEL DEFINITION 

As the MCP is requested to run an execution 
of a program, a level-1 branch of the stack is 
created. This level-1 branch is a separate stack 
which contains only the descriptors pointing to 
the executable code and the read-only data 
segments for the program. Emerging from this 
level-1 branch is a level-2 branch, containing 
the variables and data for this job. Starting 
from the job's stack and tracing downward 
through the tree structure, one finds first the 
stack containing the variables and data for 
the job (at level 2), the segment descriptor to 
be executed (at level 1), and the MCP's stack 
at the trunk (level 0). 

RE-ENTRANCE 

A subsequent request to run another execu- 
tion of an already-running program. Thus two 
jobs which are different executions of the 
same program have a common node, at level- 
1, describing the executable code. It is in this 
way that program code is re-entrant and 
shared. This results simply from the proper 
tree-structured organization of the various 
stacks within the machine. All programs 



within the system are re-entrant, including all 
user programs as well as the compilers and 
the MCP. 

JOB-SPLITTING 

The B 7700 stack mechanism also provides 
the facility for a single job to split itself into 
two independent jobs. A common use of this 
facility occurs when there is a point in a job 
where two relatively large independent proc- 
esses must be performed. This splitting can be 
used to make full use of a multiprocessor con- 
figuration, or to reduce elapsed time by multi- 
programing the independent processes. 

A split of this type establishes a new limb of 
the tree-structured stack, with the two inde- 
pendent jobs sharing that part of the stack 
which was created before the split was re- 
quested. The process is recursively defined 
and can happen repeatedly at any level. 

STACK DESCRIPTOR 

Stack branches are located by an array of 
descriptors, the stack vector array (figure II-2- 
12). There is a data descriptor in this array for 
every stack branch. This data descriptor, the 
stack descriptor, describes the length of the 
memory area assigned to a stack branch and 
its location in either main memory or disk. 

A stack number is assigned to each stack 
branch. The stack number is the index value 
of the stack descriptor in the stack vector ar- 
ray. 
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STACK VECTOR DESCRIPTOR 

The array size of the stack vector and its lo- 
cation in memory is described by the stack 
vector descriptor, located in a reserved posi- 
tion of the trunk of the stack (figure II-2-12). 
All references to stack branches are made 
through the stack vector descriptor, indexed 
by the stack number. 



PRESENCE BIT INTERRUPT 

A Presence Bit Interrupt results when an 
addressed stack is not present in memory. This 
Presence Bit Interrupt facility permits stack 
overlays and recalls under dynamic conditions.. 
Idle or inactive stacks may be moved from 
main memory to disk as the need arises and, 
when a stack is subsequently referenced, a 
Presence Bit Interrupt is generated to cause 
the MCP to recall the nonpresent stack from 
disk. 
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Figure 11-2-12. Multiple Linked Stacks 



SECTION 3 



PROCESSOR WORD FORMATS 



GENERAL 

The basic information structure of the 
B 7700 is the word. As transferred between 
CPMs or IOMs and core memory, a word con- 
sists of 52 bits (see figure II-3-1), and is consid- 
ered in three parts: a parity bit, which is used 
to maintain overall parity for the word being 
transferred; a 3-bit tag field, which indicates 
the type of information contained within the 
word, and a 48-bit information field, which 
contains the actual information. 

The tag field not only serves to identify the 
type of information contained in the word but 
also can be thought of as an extension of the 
operator being executed against the word. For 
example, because the tag field indicates to the 
arithmetic unit whether the operation involves 
single precision or double precision operands, a 
single instruction (ADD) serves both types of 
operations. In similar fashion, if the sum ob- 
tained was a double precision number (requir- 
ing two memory words of storage), and the re- 
ceiving memory word indicates that a single 
precision operand was resident there, the CPM 
will round the sum to single precision and 
then store it. 



The tag field also prevents the user from 
writing over program code or read-only data 
areas, and prevents him from reading (as 
data) program code, processor control words, 
and uninitialized operands. 

Consider the bit assignments for the tag 
field, as illustrated. One can see that words 
which have bit 48 set, such as IRW's, SIRW's, 
Segment Descriptors, MSCW's, RCW's, Data 
Descriptors, and Program Control Words, 
should not be alterable by the user. The CPM 
will not allow such words to be modified except 
by use of the overwrite operators. Words that 
are used for stack control, MSCW's, RCW's, 
and PCW's, have bits 49 and 48 of the tag field 
set. The CPM will not allow such words to be 
interpreted as operands. 

The information field may be used to store 
data (logical operands, string operands, nu- 
meric operands), to store program code (pro- 
gram word), to address data or code outside of 
the stack (data descriptor, string descriptor, 
segment descriptor), to address within stacks 
(indirect reference word, stuffed indirect ref- 
erence word, stuffed indirect reference word, 
program control word), to store information re- 
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Description 

Parity bit. Odd parity for the 52 bit word. 

Value of this field indicates the usage of the 
information field, as described below. 



Tag Value 



2 
3 

k 
5 
6 

7 



Information Field Usage 

Single Precision Operand, Logical 
Operand, String Operand, Occurs 
Index Word, Time of Day Function Word 

Indirect Reference Word, Stuffed 
Indirect Reference Word 

Double Precision Operand 

Mark Stack Control Word, Return 
Control Word, Top of Stack Control 
Word, Program Word, Segment 
Descriptor 

Step Index Word 

Data Descriptor, String Descriptor 

Uninitialized Operand 

Program Control Word 



Use of this field depends on the value of the 
tag field. 



Figure 11-3-1. Basic Word Format 
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gar ding stack history (mark stack control 
word, return control word, top of stack control 
word), or to provide a parameter for use with 
certain operators (step index word, and occurs 
index word. Data words (operands) and pro- 
gram words were described in the previous 
sections of this chapter. The other various 
processor words are described in this section. 

WORDS FOR ADDRESSING OUTSIDE OF THE 
STACK 

There are three types of descriptors which 
are used for addressing data or code which is 
not resident in the stack. The type of descrip- 
tor is directly related to the data or code being 
referenced. Thus, a segment descriptor will al- 
ways address a segment of program code (con- 
tained in program words), a string descriptor 
will always address a string operands), and a 
data descriptor will address an array of word 
operands. 

The ADDRESS field in each of these de- 
scriptors is 20 bits in length; this field con- 
tains the absolute address of an array in ei- 
ther system main memory or in the backup 
disk file, as indicated by setting of the Pres- 
ence bit (P). The referenced data is in main 
memory when the presence bit is set. 

PRESENCE BIT 

A Presence Bit Interrupt occurs when the 
job references data by means of a descriptor 
in which the P-bit is equal to 0; i.e., the data 
is located in a disk file, rather than in main 
memory. The Master Control Program (MCP) 
recognizes the Presence Bit Interrupt and 
transfers data from disk file storage to main 
memory. After the data transfer to main mem- 
ory is completed, the MCP marks the descrip- 
tor present by setting the P-bit to 1, and 
places the new main memory address into the 
address field of the descriptor. The inter- 
rupted job is then reactivated. 

INDEX BIT 

A Data Descriptor describes either an entire 
array of data words, or a particular element 
within an array of data words. If the descrip- 
tor describes the entire array, the Index bit (I- 
bit) in the descriptor in 0, indicating that the 
descriptor has not yet been indexed. The 
length field of the descriptor defines the 
length of the data array. 

INVALID INDEX 

A particular element of an array is de- 
scribed by indexing an array descriptor. Mem- 
ory protection is ensured during indexing op- 



erations by performing a comparison between 
the length field of the descriptor and the index 
value. An Invalid Index Interrupt results if 
the index value exceeds the length of the 
memory area defined by the descriptor, or if 
the index is less than 0. 

VALID INDEX 

If the index value is valid, the length field of 
the descriptor is replaced by the index value, 
and the I-bit in the descriptor is set to 1 to in- 
dicate that indexing has taken place. The ad- 
dress and index fields are added together to 
generate the absolute machine address when- 
ever an indexed Data Descriptor in which the 
P-bit is set is used to fetch or store data. 

The Double-Precision bit (D) is used to iden- 
tify the referenced data as single-or double- 
precision and directly affects the indexing op- 
eration. The D-bit equal to 1 signifies double- 
precision and causes the index value to be dou- 
bled before indexing. 

READ-ONLY BIT 

The Read-Only bit (R) specifies that the 
memory area described by the Data Descriptor 
is read-only area. If the R-bit of a descriptor 
is set to 1, and the area referenced by that de- 
scriptor is used for storage purposes, an inter- 
rupt results. 

COPY BIT 

The Copy bit (C) identifies a descriptor as a 
copy of a master descriptor and is related to 
the presence-bit action. The copy bit links mul- 
tiple copies of an absent descriptor (i.e., the 
presence bit is off) to the one master descrip- 
tor. The copy bit mechanism is invoked when 
a copy is made in the stack. If it is a copy of 
the original, absent descriptor, the processor 
sets the copy bit to 1 and inserts the address 
of the master descriptor into the address field. 
Thus, multiple copies of absent data descrip- 
tors all point back to the master descriptor. 

DATA DESCRIPTOR 

Data descriptors refer to data areas, includ- 
ing input/output buffer areas. The data de- 
scriptor defines an area of memory starting at 
the base address contained in the descriptor. 
The size of the memory area in operands is 
contained in the length field of the descriptor. 
Data descriptors may directly reference any 
memory word address from through 
1,048,576. The structure of the data descriptor 
is illustrated in figure II-3-2. 

STRING DESCRIPTOR 

String descriptors refer to strings of 4-bit 
digits, 6-bit or 7-bit characters, or 8-bit bytes. 



2-27 





P 

47 


R 

43 


39 


35 


31 


27 


23 


19 


15 


11 


7 


3 


>50 


^46 


O42 


L.EN 

381 34 


GTH 

30 


OF? 

26 22 


18 


ADDRESS 

14 10 6 


2 


049 


1 45 


0« 


37 


INDEX 

33 29 25 


21 


(MEMOR v OR 

17 13 9 5 1 


' 48 


S 44 


D 40 


36 


32 


28 


24 


20 


16 


DISH) 

12 8 4 






Field 


Bits 


Tag 


50:3 


P 


47:1 


C 


46:1 


I 


45:1 


s 


44:1 


R 


43:1 




42:2 


D 


40:1 


Length 
or Index 


39:2( 


Address 
(Memory 
or Disk) 


19:2( 



Description 

Tag field. Value of five. 

Presence bit. Indicates the presence or absence of data in main memory. A causes a 

presence bit interrupt whenever the descriptor is used by a processor to obtain non-present 

data. A 1 indicates that the data described is in main memory. 

Copy bit. A indicates that this is the original descriptor for the particular data area. A 1 

indicates that this descriptor is a copy of the original descriptor. 

Indexed bit. A indicates that an indexing operation is required before the descriptor may be 

used to obtain data. A 1 indicates that indexing has already taken place and the index value 

is stored in bit positions 39:20 (Length or Index). 

Segmented bit. A indicates that the data is not segmented. A 1 indicates that the data is 

divided into segments. 

Read-only bit. A indicates that the data may be referenced for reading or writing. A 1 

indicates that the data can only be referenced for reading. 

Size field, must be to indicate a data descriptor. 

Double-precision bit. A indicates single-precision operands, a 1 indicates double-precision 

operands. 

This field contains either the length (in operands) of the memory area (if bit 45 = 0) or an 

index value (if bit 45 = 1). If bit 45 equals 0, the descriptor has not been indexed. This field 

is used for size checking during the indexing operation. If bit 45 equals 1, the descriptor has 

been indexed. For a double-precision operation, the index is doubled after index size checking, 

and the result is stored in the index field. 

This field contains either a main memory or disk address. If the presence bit (bit 47) equals 1, 

this field contains the memory address of data. If the presence bit equals and the copy bit 

(bit 46) equals 0, this field contains the disk address of the data. If the presence bit equals 

and the copy bit equal 1, this field contains the memory address of the original descriptor. 



Figure 11-3-2. Data Descriptor 



The string descriptor defines an area of 
memory starting at the base address con- 
tained in the descriptor. The size of the 
memory area in characters is contained in the 
length field of the descriptor. The structure of 
the String Descriptor is illustrated in figure 
II-3-3. 



SEGMENT DESCRIPTORS 

Segment descriptors refer to areas of pro- 
gram code. The descriptor defines an area of 
memory starting at the base address con- 
tained in the descriptor. The size of the 
memory area in program words is contained in 
the length field of the descriptor. The struc- 
ture of the segment descriptor is illustrated in 
figure 1 1-3-4. 



WORDS FOR ADDRESSING WITHIN STACKS 

There are three types of words which are 
used for addressing data or descriptors which 
are resident within a stack. A Program Con- 
trol Word is used, at the time of procedure en- 
try, to locate a segment descriptor (and the 
proper word and syllable of code) for the pro- 
cedure. An Indirect Reference Word is used to 
address within the current addressing envi- 
ronment of a procedure. A Stuffed Indirect 
Reference Word is used to address outside the 
current addressing environment of a proce- 
dure. 

PROGRAM CONTROL WORD 

The Program Control Word (PCW), and the 
MSCW are used during entry into a procedure. 
The organization of the PCW is illustrated in 
figure II-3-5 and contains the following: 
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45:1 



44:1 



43:1 



42:3 



39:20 



Description 

Tag field. Value of five. 

Presence bit. A causes a presence bit interrupt if the descriptor is used to access data. A 1 
indicates the data is present in main memory. 

Copy bit. A indicates that this is the original descriptor for the particular data area. A 1 
indicates that this descriptor is a copy of the original descriptor. 

Indexed bit. A indicates indexing is required. A 1 indicates that indexing has taken place 
and the word and character index are in the WORD INDEX and BYTE INDEX fields. 

Segmented bit. A indicates that the data area is not segmented. A 1 indicates that the data 
is segmented. 

Read only bit. A indicates that the data may be referenced for reading or writing. A 1 
indicates that the data can be read only. 

Size field. 100 indicates character size of 8-bit bytes, 101 indicates 7-bit ASCII characters, 011 
indicates 6-bit characters, and 010 indicates 4-bit digits. 

Bits 39:20, contain either the length of the memory area (bit 45=0) or an index value (bit 
45=1). When bit 45 equals 0, this field contains the length of the area in digits, characters or 
bytes. 



39:4 Byte index (Bit 45=1). 



35:16 Word Index (Bit 45=1). 



19:20 This field contains either a main memory or a disk address. If the presence bit (bit 47) is 1, 

the field contains a memory address of the data. If both the presence bit and the copy bit (bit 
46) are equal to 0, the field contains the disk address of the non-present data. If the presence 
bit is and the copy bit is 1, the field contains the memory address of the original descriptor. 



Figure 11-3-3. String Descriptor 



INDIRECT REFERENCE WORD 

Referencing a variable within the current 
addressing environment of a procedure is ac- 
complished through the address couple in the 
Indirect Reference Word (IRW). References 
are relative to the D register specified by the 
address couple. The format of the IRW is 
shown in figure 1 1-3-6. 



STUFFED INDIRECT REFERENCE WORD 

Reference to variables outside the current 
environment is accomplished by a Stuffed In- 
direct Reference Word. This addressing is 
relative to the base of the stack in which the 
variable is located. 

The SIRW contains the stack number, the lo- 
cation (DISP) of the MSCW, and the index to 
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Field Bits Description 

Tag 50:3 Tag field. Value equals three. 

P 47:1 Presence bit. A indicates that the segment is absent from main memory. 

C 46:1 Copy bit. A indicates that this is the original segment descriptor. A 1 indicates that this is 

a copy of the original segment descriptor. 
45:4 Not used. Unused bits may be either or 1, 
Length 39:20 The length of the program segment in words. 

Address 19-20 This field contains either the main memory address or the disk file address. If the presence 
(Memorv bit (bit 47 equals 1, the field contains the main memory address of the program segment. It 

or Disk) both the presence bit and the copy bit (bit 46) equal 0, the field contains the disk address of 

the non-present program segment. If the presence bit equals and the copy bit equals 1, the 
field contains the absolute memory address of the original program segment descriptor. 



Figure 11-3-4. Segment Descriptor 
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Description 

Tag field. Value equals seven. 

Not used. 

The number of the stack which contains the PCW. 

The program syllable (0-5) within the word located by PIR. 

Index to the Program Base Register. Locates a word within the code segment. 

Normal state (0) or control state (1). 

The level of the procedure being entered. 

The segment descriptor index. Bits 12 through specify the value to be added to either D- 

register or 1. When bit 13 equals 0, D-register is selected; when bit 13 equals 1, D-register 

1 is selected. The sum of the contents of the display register and the index locates a segment 

descriptor. 



Figure 11-3-5. Program Control Word 
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Field Bits Description 

Tag 50:3 Tag field. Value equals one. 

47:1 Not used 

46:1 Environment bit. Must equal zero for an IRW. (1 = SIRW). 

45:32 Not used. 

Address 13:14 Selects D Register (According to current program level as indicated by rLL) and provides index 

Couple value (see below). 
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Figure 11-3-6. Indirect Reference Word 
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the variable relative to the MSCW. The abso- 
lute memory location of the variable is formed 
by adding the contents of DISP and index to 
the base address of the referenced stack from 
the stack descriptor. The contents of the SIRW 
(with the exception of index) are dynamic and 
are accumulated as the program is executed. 
The stack number and DISP fields are entered 
into the SIRW by the Stuff Environment 
(STFF) operator. The bit format of the SIRW 
is shown in figure II-3-7. 



WORDS FOR STORING STACK HISTORY 

Certain words can be thought of as words 
used for storing stack history. These words, 
used for procedure entry and exit, as well as 
for storing the stack state for inactive stacks, 
include the Mark Stack Control Word, the Re- 
turn Control Word, and the Top Of Stack Con- 
trol Word. 

MARK STACK CONTROL WORD 

The Mark Stack Control Word (MSCW), to- 
gether with the Return Control Word (RCW), 
provides a linking mechanism for the history 
of previous control-register settings through 
the stack. 

The MSCW is placed in the stack by the 
Mark Stack operator. The MSCW is organized 
as illustrated in figure 1 1-3-8. 



RETURN CONTROL WORD 

The Return Control Word (RCW) and the 
MSCW are used for subroutine handling. The 
Return Control Word stores the environment 
to which the subroutine will return. The or- 
ganization of the RCW is illustrated in figure 
II-3-9. 

TOP OF STACK CONTROL WORD 

The Top Of Stack Control Word (TOSCW) 
contains all information needed to restore the 
operating environment when a stack (or proc- 
ess) is activated. When a stack is active, the 
first word of the stack is a single precision op- 
erand containing the processor ID (a number, 
through 7). When the stack is made inactive, 
the processor ID is changed to a TOSCW, con- 
taining the status of various processor flip- 
flops necessary to restore the stack's environ- 
ment when it is again activated. The TOSCW 
is created by the Move Stack (MVST) operator. 
The TOSCW is illustrated in figure II-3-10. 

WORDS USED AS SPECIAL PARAMETERS 

Certain control words are used only as a pa- 
rameter to a single operator. Among these are 
the Step Index Word, used with the Step and 
Branch operator; the Occurs Index Word, used 
with the Occurs Index operator; and the Read 
Time Of Day Function Word, used with the 
Scan In operator. 
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Field Bits Description 

Tag 50:3 Tag field. Value equals one. 

47:1 Not used. 

46:1 Environment bit. Must be a one (0=1RW). 

Stack No. 45:10 The number of the stack containing the referenced word. 

Displace- 35:16 This number, added to the stack base address, addresses an MSCW. 
ment 

19:6 Not used. 

14:1 Must be 0. 

Index 12:13 This number, added to the address of the MSCW, addresses the referenced word. 



Field 



Figure 11-3-7. Stuffed Indirect Reference Word 
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Number 
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Description 

Tag field. Value equals three. 

Different-stack bit. A indicates that the stack-number field refers to the current stack A 1 
indicates that the stack-number field refers to a different stack. 

Environment bit. A indicates an inactive USCW, generated directly by the Mark Stack 
operator. The procedure entry has not been performed. A 1 denotes an active MSCW generated 
upon ertry into a procedure, at which time the environment fields (stack number, displacement, 
value, and LL fields) are stored into the MSCW. 

Stack-number field. Contains the number of the stack from which the PCW was obtained at 
procedure-entry. 

Displacement field. When added to the stack base address, locates the MSCW of the prior 
lexicographic level. 

Value bit. A indicates that the MSCW was generated during any operation that will be 
restarted from the beginning. A 1 indicates that the operator must continue after the Exit or 
Return which refers to this MSCW (e.g., an accidental entry by a Value Call). 

LL field. Denotes the lexicographical level at which the program will run when the procedure 
is entered. 

Denotes the stack history. This field is used to locate, in the stack, the preceding MSCW (i.e., 
the previous "F" register setting). 



Figure 11-3-8. Mark Stack Control Word 



STEP INDEX WORD 

The Step Index Word (SIW) is used as a pa- 
rameter to the Step and Branch operator, to 
increase the efficiency of this operator in 
iteration loops. When the Step and Branch op- 
erator is invoked, the SIW addressed by the 
IRW in the top of stack location is located. The 
increment field is added to the current value 
field. If the current value field is then greater 
than the final value field, PIR and PSR are 
set from the next two syllables in the program 
code string and the branch is made. If the cur- 
rent value field is not greater than the final 
value field, PIR and PSR are advanced three 
syllables, the SIW is replaced in memory, and 
the iteration loop continues. The format of the 
SIW is illustrated in figure 1 1-3-11. 

OCCURS INDEX WORD 

The Occurs Index Word (OIW) is used to in- 
dex a field within an array. COBOL permits 
arrays to be constructed of a series of fields of 
a specified character size (through use of the 
OCCURS clause). This series of fields may not 



necessarily begin at a word boundary, because 
the array may be one of several items subordi- 
nated under a group item. The OCRX 
operator, together with an OIW in the A loca- 
tion and an index value in the B location, is 
used to calculate a new index value which is 
left in the top of the stack. The original index 
value is an integer which indicates the 
relative position of the desired field within the 
array. The new index value is the displace- 
ment (in characters) of the desired field from 
the first character of the array. The character 
size (specified in a descriptor) and the index 
value (left in the top of stack) can then be 
used to address the desired field. The format 
of the OIW is shown in figure II-3-12. 



TIME OF DAY FUNCTION WORD 

This word is used as a parameter to the 
Scan In operator, to specify that the time of 
day is to be interrogated by the MCP. The for- 
mat of the Time of Day Function Word is 
shown in figure II-3-13. 
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Description 

Tag field. Value of three. 

External Sign flip-flop. 

Overflow flip-flop. 

True/False flip-flop. 

Float flip-flop. 

True/False flip-flop occupied flip-flop. 

Special hardware bits. These bits are used for controlling display update operations in the 

processor. 

Program syllable of the operator to be executed after return from the subroutine. 

PIR setting of the operator to be executed next in the calling routine. 

Normal state (0) or control state (1) procedure. 

Level of the calling procedure when the RCW was generated (at procedure entry). 

Segment descriptor index. Bits 12 through specify the value to be added to either B-regirter 

or 1 When bit 13 = 0, D-register is selected; when bit 13 = 1, D register 1 is selected. The 

sum of the contents of the selected display register and the index locates a segment 

descriptor. 



Figure 11-3-9. Return Control Word 
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Description 

Tag field. Value equals three. 

External sign flip-flop. 

Overflow flip-flop. 

True/False flip-flop. 

Float flip-flop. 

Not used. 

Delta S-register field. The value of S-register displacement above BOSR. 

Normal-control state flip-flop. = normal; 1 = control state. 

Lexicographic level. 

Delta F-register field. The value of F-register displacement below the S-register. 



Figure 11-3-10. Top of Stack Control Word 
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Description 



Field Bits 

Tag 50:3 Tag field. Value equals four. 

Increment 47:12 Increment: value to be added to current value field. 

35:16 Pinal value: value used to terminate the iteration loop. 



Final 

Value 



19:4 Must be for S1W. 



Current 15:16 Current value or count. The branch is made if this field is greater than the final value field. 
Value 

Figure 11-3-11. Step Index Word 
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Description 



Field Bits 

Tag 50:3 Tag field. Value equals zero. 

Length 47:16 The length, in characters, of each field in the array. 

Size 31:16 The size, in fields, of the array. 

Offset 15:16 The number of characters preceding the first field of the array. 

Figure 11-3-12. Occurs Index Word 
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Field Bits Description 

Tag 50:3 Tag field. Value equal zero. 

47:28 Not used. 

19:13 Must equal zero. 

6:2 Must equal three. 

4:5 Must equal zero. 

Figure 11-3-13. Time-of-Day Function Word 
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SECTION 4 



INPUT/OUTPUT SUBSYSTEM MAP STRUCTURE 



INTRODUCTION 

The B 7700 Input/Output Modules (IOM) op- 
erate in parallel with the Central Processor 
Modules (CPM). The purpose of the IOM is to 
control all data transfers between main 
memory and peripheral devices, or between 
two peripheral devices, so that the CPM is re- 
leased from I/O operations at the earliest pos- 
sible moment. In brief, the IOM controls not 
only the selection of I/O requests from lists of 
such requests in main memory, but also path 
selection to the desired devices, the initiation 
of requests on the appropriate device, the 
transfer of data as specified by the requests, 
and the construction of a list of completed re- 
quests in main memory. The CPM, on the 
other hand, builds the I/O request, places it in 
the appropriate list in main memory, notifies 
the IOM of the presence of the request (if this 
is the only request for the device), and then is 
free to continue with other processing. Rou- 
tinely, the CPM checks memory for the pres- 
ence of completed I/O requests and processes 
the completed requests. 

Each IOM is, in effect, a separate computer 
with its own local memory, logic, arithmetic, 
and communication capabilities. This inde- 
pendent processing capability permits the IOM 
to perform routine input-output tasks without 
interrupting the CPM. Thus the IOM can con- 
trol transfers of data between peripheral stor- 
age devices and main memory or other storage 
devices without direct supervision of the CPM. 
In fact, parallelism within the IOM permits it 
to initiate, service, and terminate data trans- 
fers for several users while the CPM is proc- 
essing data for yet another user. 

QUEUE-DRIVEN I/O 

To allow the IOMs to properly select paths 
to the devices and to service I/O requests, cer- 
tain structures are created by software when 
the system is initialized. These structures, 
which provide a mechanism to allow the CPMs 
to queue I/O requests, allow each IOM to be 
aware of the requests, of the devices it can 
service, and of the order of priority of devices 
served by an exchange. These structures are 
referred to as the I/O Subsystem Map, and 
hence this type of I/O is often reffered to as 
"map" I/O or "queue-driven" I/O. Because the 
use of the map allows the IOM to process 



many I/O operations in parallel, independent 
of CPM, I/O performed using the map is also 
known as asynchronous I/O. The IOM may 
also operate synchronously to process one I/O 
request at a time; however, such synchronous 
operation is used only for special applications 
such as system initialization and is not fur- 
ther discussed in this section. 

The operation of asynchronous I/O is illus- 
trated in simplified form in figure II-4-1. When 
the I/O subsystem map is initialized the CPM 
places information about each peripheral de- 
vice and the paths to it into a table in 
memory. During operation, the I/O subsystem 
map is accessed by both the CPM and IOM as 
I/O requests are built (by the CPM) and proc- 
essed (by the IOM). In essence, the CPM builds 
I/O requests and places them in queues of 
such requests in main memory. Each request 
specifies the desired I/O operation and the de- 
vice on which the operation is to be performed. 
The IOM extracts requests from these queues 
on a first-in first-out basis, processes each re- 
quest, and places the completed requests into 
a queue in main memory. 

Periodically, the CPM extracts the completed 
requests from the queue in main memory and 
takes the necessary action to check them. 
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Figure 11-4-1. Asynchronous I/O Operation, 
Simplified Block Diagram 
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Once the IOM is notified (by the CPM) of the 
presence of an I/O request in one of the input 
queues, all requests in that queue will be proc- 
essed by the IOM independent of CPM actions 
until the queue becomes empty. The CPM may 
place additional requests into a queue while 
the IOM is processing a request from the 
queue. Thus, once the IOM starts processing a 
queue, the CPM may process other programs, 
queue new I/O requests, and perform computa- 
tions; effectively masking out the IOM trans- 
fer times. 

ERROR HANDLING 

From time to time conditions may arise 
which prevent I/O operations from being ac- 
complished successfully. A printer may run 
out of paper, a card punch may be out of 
cards, or a device may for some reason not be 
ready. The design of the I/O subsystem map 
allows the IOMs to continue to process re- 
quests for other devices even though an error 
is detected on a particular device. When the 
error is recognized by an IOM, processing of 
further requests for the particular device is 
suspenended, the I/O request is marked as 
containing an error, and that marked request 
is linked into the queue of completed requests. 
The CPM is not interrupted to handle the er- 
ror; however, when the CPM does process the 
queue of completed requests it will recognize 
and process the error. When the error has 
been processed, the CPM can again cause the 
IOM to process requests for the device on 
which the error was detected. 



If such a strategy were to be applied to the 
handling of all input/output errors a 
catastrophic situation might arise. If, say, the 
IOM itself were the source of the error, it is 
conceivable that it could then process all (or 
many) I/O requests erroneously. However, in 
such cases the B 7700 IOM stops all processing 
of I/O requests (for all devices) and immediate- 
ly interrupts the CPM. In short, I/O errors as- 
sociated with a particular device cause proc- 
essing of further requests for the device to be 
halted but allow the processing of requests for 
other devices by the IOM to continue. I/O er- 
rors which can be associated only with an IOM 
and not with a particular device cause the 
IOM involved to stop all processing of requests 
(other IOMs are not affected) and causes the 
system to be interrupted so that the IOM er- 
ror may be processed. Provision is also made 
to allow the software to request that the sys- 
tem be interrupted when a particular I/O re- 
quest is completed. 



DEFERMENT OF PATH BINDING 

The I/O subsystem map allows the IOM to 
select the transfer path for a device as the 
path becomes available. This dynamic path se- 
lection is logically similar to the call routing of 
a long distance telephone network; that is, the 
route of the call is selected based on the loca- 
tions of the correspondents and the available 
paths. The user need only be concerned about 
the type of device to be used (card reader, 
magnetic tape, disk file, etc.); the MCP will as- 
sociate the logical file with a physical device 
when the program is executed, and the IOM, 
when it initiates each transfer of data, will se- 
lect an available transfer path to the device. 

Maximum I/O throughput can be realized 
only if the binding of the data path between 
an IOM and a device is delayed until the de- 
vice is ready to initiate the job. As shown in 
figure II-4-2, if device 4 is to be initiated, the 
path required to connect CPM 1 with device 4 
involves selecting between two IOM's and be- 
tween two channels within each IOM. (The pe- 
ripheral controls have been excluded from this 
figure because they do not affect the concepts 
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Figure 11-4-2. Data Transfer Path Selection 
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being described. For purposes of this discus- 
sion the peripheral controls may be thought of 
simply as extensions of the IOMs.) If the path 
to device 4 were to be preselected program- 
matically, a situation could develop in which 
the device is free but the preselected path is 
not. Thus, execution of the request would be 
unnecessarily delayed if in fact an alternate 
path to the device was available. 

To delay binding the path programmatically 
generally would require that the CPM which 
initiated the job be involved in the operation 
until the request is actually initiated on the 
specified device. The I/O subsystem map, how- 
ever, allows the IOM's to manage selection 
and binding of paths, allowing the CPM's to be 
free to do other processing. Thus, because the 
IOM processes I/O requests without CPM in- 
tervention, and because the IOM selects data 
paths at the time of execution, the total sys- 
tem time required to accomplish an I/O 
operation is limited to the amount of time re- 
quired for a CPM to build an I/O request and 
place it in memory. 



I/O SUBSYSTEM MAP 

As shown in figure II-4-3, the I/O subsystem 
map is made up of four major software struc- 
tures in main memory. These four software 
structures are addressed by registers within 
the IOM: the Home Address words are ad- 
dressed by the HA register; the Unit Table is 
addressed by the UT register; the Queue Head 
and Queue Tail words table is addressed by 
the QH register; and the Status Queue Header 
is addressed by the SQ register. The IOM uses 
the Queue Head word for the appropriate de- 
vice to locate the I/O request. Thus, the IOM 
can locate any element of the map as neces- 
sary. Of course, since the map is constructed 
by the MCP, it too is aware of the location of 
each element of the map. 

COMMANDS AND REQUESTS 

Before further discussion of the I/O subsys- 
tem map can take place, the difference be- 
tween an I/O command and an I/O request 
must be made clear. An I/O command is an or- 
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Figure 11-4-3. I/O Subsystem Map, Simplified Block Diagram 
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der to an IOM which can cause one operation 
or many operations for one device to be initi- 
ated by the IOM. Although there are special 1/ 
O commands which control but a single I/O op- 
eration, the I/O command most often associ- 
ated with asynchronous I/O is the Start 10 
command, which causes the IOM to process 1/ 
O requests from a queue of such requests until 
the queue is empty. Each I/O request contains 
information describing a single input or out- 
put operation that is used not only by the IOM 
but also by the peripheral control and even 
the device itself. Each I/O request is made up 
of several words and is known as an I/O Con- 
trol Block (IOCB). The IOCB is discussed in de- 
tail later in this section; I/O commands are de- 
scribed in Chapter IV. 

MAP INTEGRITY 

Because the I/O subsystem may be accessed 
and modified by all CPM's and IOM's in the 1/ 
subsystem, the integrity of the map is pro- 
tected by special lock bits and lock words. This 
system of locks prevents conflicts between the 
IOM's and CPM's which use and modify the 
map. As shown in figure II-4-4, the system 
consists of three types of locks; a lock bit and 
a lock word for each group of Home Address 
words, and a lock bit for each Unit Table word. 

The software lock word prevents two or 
more CPM's from attempting to build I/O com- 
mands in the Home Address words simultane- 
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Figure 11-4-4. I/O Subsystem Map Protection 



ously. This word must be unlocked before a 
CPM can access the Home Address words; the 
CPM will immediately lock this word when it 
gains access. 

The Home Address lock bit prevents a com- 
mand from being altered once it has been 
placed in the Home Address words for execu- 
tion. The CPM locks this bit when a command 
is placed in the Home Address words. 

In response to a channel interrupt, the IOM 
exchanges the contents of HA word with zero, 
decodes the home command, and executes the 
operation. When a CPM gains access to an HA 
block via the software lock-word, the CPM 
does not insert a HA command into the Home 
Address word until the HA lock bit is un- 
locked. 

The lock bit in each Unit Table word pro- 
tects the 10 queues so that access to an I/O 
queue is not granted to more than one IOM or 
CPM at a time. The I/O queue can only be ac- 
cessed when the lock bit is unlocked. Each 
IOM or CPM locks the bit when it is using the 
I/O queue and unlocks the bit when it is fin- 
ished. 

HOME ADDRESS WORDS 

P'or each IOM there exists a unique set of 
Home Address words in memory. The basic 
purpose of the Home Address words is to pro- 
vide a location into which CPM's can store an 
I/O command until an IOM is ready to execute 
the command. The most generally used com- 
mand is Start 10, which is used to initiate the 
processing of a queue of I/O requests for a de- 
vice by an IOM. Other commands allow the 
IOM to perform special functions, such as 
loading into the IOM the addresses of the 
structures in the I/O map or performing syn- 
chronous I/O operations. Other words in the 
Home Address words are used as software lock 
words and, in certain cases, to store result de- 
scriptors for completed I/O operations. 

UNIT TABLE 

For each device in the I/O subsystem there 
is one word in the Unit Table. This word is 
used both by the MCP and the IOM, and con- 
tains a lock bit which prevents conflicts of 
interest. This word indicates the path or paths 
to the unit, and provides other information 
needed by the IOM. 

I/O QUEUE HEAD AND TAIL WORDS 

For each device in the I/O subsystem there 
is one Queue Head word and one Queue Tail 
word. These words contain the address of the 
first IOCB and the last IOCB, respectively, in 
the queue of I/O requests for the unit. If there 
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are no IOCB's to be processed for the unit, 
these words will be empty. 

STATUS QUEUE HEADERS 

For each IOM there is a Status Queue 
Header. Fields in the Status Queue Header 
contain the addresses of the first and last 
IOCB in a queue of completed IOCB's. Thus, 
the Status Queue Header allows each IOM to 
maintain a single queue of completed I/O re- 
quests. Periodically, the MCP checks these 
completed requests. 

INPUT/OUTPUT CONTROL BLOCK 

An Input/Output Control Block (IOCB) con- 
tains the information needed by the IOM to 
perform one I/O operation on a device. I/O 
Control Blocks (see figure II-4-5) contain infor- 
mation needed to link queues of IOCB's to- 
gether, to describe the I/O operation to be per- 
formed, to locate the data buffer to be used 
for the operation, and in the case of completed 
IOCB's, to store the result descriptor describ- 
ing the completed operation. A generalized il- 
lustration of an IOCB is shown in figure 1 1-4- 
5. 
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CHAPTER III 
CENTRAL PROCESSOR MODULE 



SECTION 1 



FUNCTIONAL DESCRIPTION OF THE CENTRAL PROCESSOR MODULE 



The B 7700 Central Processor Module, 
which is a highly parallel machine and com- 
pletely program-compatible with the B 6700 
Processing System, consists of three major 
functional sections that are operationally inde- 
pendent: 

a. The program section, which performs in- 
struction decoding operations of object code 
strings and address calculations of absolute 
addresses. 

b. The execution section, which performs all 
arithmetic and logical data manipulation oper- 
ations. 

c. The storage section, which performs all 
storage related functions. 

Figure III-l-l is a simplified block diagram 
showing the general interconnections and data 
flow between the three sections. Communica- 
tions between the sections is established by 
operations queues. 

The program section consists of the program 
buffer and barrel, program control unit, the 
fault control logic and the address unit. The 
program section is responsible for extracting 
each instruction from the program code string 
and initiating processing of the instructions, 
and for the update of the program index and 
program syllable registers. The program sec- 
tion also controls and responds to the fault in- 
terrupt system. The primary responsibility of 
the program section is to separate the object 
code string into operations which are then 
placed in the appropriate queues for execution 
section. A few instructions are executed en- 
tirely by the program section, such as an un- 
conditional branch, and others are executed in 
part, such as the address calculation portion of 
Value Call. 

The execution section consists of the execu- 
tion unit and the execution unit input queues. 
The execution section is responsible for all 
data and control manipulations. The execution 
section performs all arithmetic and logical op- 
erations as well as stack related control func- 
tions. The execution section is driven in an or- 



derly manner from a first in first out list of 
operations placed in its operator queue by the 
program section. 

The storage section consists of the storage 
unit, the stack buffer unit, the associative 
memory and the communications unit. The 
storage section is responsible for all storage 
related functions. Some of the storage sec- 
tion's duties are implied such as maintaining 
the stack buffer, but most operations are ex- 
plicit in that they result directly from the 
processing of program code. Implicit 
operations for the storage section are placed 
in the input queue of the storage unit by the 
program section or in the storage output regis- 
ter by the execution section. It is the responsi- 
bility of the storage section to determine if an 
address reference points to local storage or to 
main memory, in which case, a main memory 
cycle is necessary. 

These major sections are subdivided into 
units which operate relatively independently. 
The operation of each of the units of the CPM 
is described separately. First some of the basic 
operational concepts of the CPM are presented 
to aid in understanding the physical and con- 
ceptual design of the Central Processor Mod- 
ule. 

In general, the program operators in the 
program code string are fetched from memory 
in multi-word segments and placed in the pro- 
gram buffer. The operators are extracted one 
at a time by the program control unit and 
each is separated into one or more micro oper- 
ators, which are queued for processing by the 
execution unit. When possible the program 
control unit determines what data will be re- 
quired for execution of the micro operators 
and requests this data from the storage unit. 
For literal values, which are contained in 
the code string, the program control unit ex- 
tracts the data and forwards it directly to the 
execution unit. Therefore, as the execution 
unit processes the micro operators, the re- 
quired data is usually available, allowing the 
execution unit to perform the required proc- 
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essing without delay. Results derived by the 
execution unit may e:ither be stored in one of 
the local memory areas or may be sent 
through the storage unit and the communica- 
tions unit to main memory. By using this pipe- 
line technique, relatively high-speed process- 
ing has been achieved without compromising 
equipment reliability. 

To further increase processing speed, exten- 
sive use has been made of buffer memory 
areas contained within the processor. These lo- 
cal memory areas are used to store program 
code, a portion of the active program stack, 
and referenced variables. The following exam- 
ple shows how these local memory areas in- 
crease processing speed by eliminating many 
memory references. 



OPERATIONAL CONCEPTS OF THE CENTRAL 
PROCESSOR MODULE 

The B 7700 Central Processor Module (CPM) 
is designed as a pipeline processing unit; 
therefore each processing station may be oper- 
ating simultaneously on a different task. As 
any instruction is passed through the process- 
ing pipeline, successive operations are per- 
formed by the various processing stations un- 
til the instruction is fully executed. 



USE OF DIVISION OVERLAP AND LOCAL 
BUFFERING 

Figure III-1-2 shows a simple statement 
along with its compiler generated code and 
traces each operator as it is encountered in 
each of the major processing units. 

The sequence begins: as the first Value Call 
arrives at the program control unit. This unit 
selects the appropriate display register and 
calculates the absolute address. 

The address and operator are placed in the 
input queue of the storage unit. At the same 
time, the operator is placed in the input queue 
of the execution unit. The execution unit then 
begins to wait for the return of the value. 
Next, the program control unit processes the 
Name Call. Detection of the Name Call alerts 
the program control unit to look at the next 
instruction to set the context of the Name 
Call. 

The appearance of the Index allows the 
Name Call to be concatenated with the Index 
operator. The address calculation is performed 
and the address and operator are placed in the 
storage unit's queue. A micro operator indicat- 
ing a concatenated Name Call is placed in the 
execution unit queue. The Index operator is 
now placed in the execution queue. 



The second Value Call is then processed by 
the program unit and the address and 
operator are placed in the queues. During this 
time, the storage unit has been busy with the 
first Value Call. The program control unit now 
has the second Name Call and has finished its 
concatenation investigation and subsequence 
address calculation. It then places the address 
and operator in the storage unit queue and 
passes another pseudo operator to the execu- 
tion unit. The storage unit just prior to this 
has completed the first Value Call, which was 
found in the stack-buffer area of the proces- 
sor, and has passed the operand to the waiting 
execution unit. The storage unit now goes to 
the next item in its queue, the first Name Call 
reference. 

The execution unit investigates the control 
information of the first Value Call and places 
it in the top-of-stack location. The execution 
unit is now waiting for the Name Call refer- 
ence which will be found local in the stack buf- 
fer and thus will be transferred by the storage 
unit. At the same time, the program control 
unit has placed the Index Load Value in the 
execution unit queue. The storage unit finds 
the first Name Call reference to be local in the 
stack buffer and places it in the execution unit 
queue. The execution unit now begins the In- 
dex function and the storage unit goes on to 
the second Value Call and then on to the sec- 
ond Name Call. 

The execution unit subsequently accepts 
both of these calls through its queue and be- 
gins the computation involved with the Index 
Load Value instruction. When the execution 
unit supplies to the storage unit the address 
for the fetch, the memory reference is initi- 
ated, if the data to be fetched is not in local 
memory, and the execution unit holds until 
the return of the value. Upon return of the 
value, the execution unit places the data in 
the storage unit. These units remain in sync 
until the store is completed. 

The program control unit has, at this point, 
proceeded to the Branch instruction, but prior 
to this, a temporary hold was placed on the pi- 
peline, because the Index Load Value operator 
has caused the execution unit queue to go full. 
The hold was released as soon as a slot became 
available and the program control unit went 
on to the branch. 

The branch point is calculated and presented 
to the program buffer control for local test. If 
the branch point is within the portion of pro- 
gram code held in the program buffer, the lo- 
cal pointers are readjusted and processing con- 
tinues. If the code at the branch address is not 
available in the program buffer, then a main 
memory reference is initiated by the storage 
control unit. 
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MEMORY OVERLAP 

In the preceding example, all reference data 
were found in the local buffers. However, the 
pipeline processing technique is efficient even 
when none of the required data is found local. 
This efficiency is illustrated by the following 
example. 

As shown in figure III-1-3, the program con- 
trol unit progresses without interruption 
through the entire sequence of code. All three 
Value Calls are found to require main memory 
fetches. The execution unit expends much of 
its time waiting for the first two Value Calls 
to be transferred into its queue by the storage 
unit. The third Value Call, however, complete- 
ly masks the multiply time. Although average 
time was used for multiply in the diagram, a 
maximum multiply would still conclude before 
the third Value Call arrived at the execution 
unit queue. The program control unit again 
took advantage of concatenating the Name 
Call and thus reduced the time necessary for 
the execution unit's portion of the store. The 
Branch instruction was again completed long 
before the execution unit reached this point in 
the program. 

PROGRAM BUFFER 

The program buffer provides local storage 
for up to 32 words of the executing program's 
object code. The algorithm for loading the buf- 
fer is based on anticipation rather than wait- 
ing until all code in the buffer has been proc- 
essed, so that full advantage is taken of the 
natural idle time on the main memory bus. Be- 
cause an average of 3.5 instructions 
(operators) are contained in each program 
word, program loops are often entirely con- 
tained within the buffer. Therefore, in many 
cases, branching may take place without a 
main memory reference for the new program 
word. (A branch which may be made with no 
main memory reference is referred to as a "lo- 
cal branch." 

In addition, by fetching the code for the pro- 
gram buffer in multi-word blocks, the number 
of memory accesses required is significantly 
reduced. 

As shown in figure III-1-4, the IC-memory 
storage area of the program buffer is ar- 
ranged in four blocks, with eight 60-bit words 
in each block. Each eight- word block is further 
divided into odd and even segments. For exam- 
ple in block 0, words 0, 2, 4, and 6 constitute 
the even segment, and words 1, 3, 5, and 7 con- 
stitute the odd segment. 



BUFFER WORD FORMAT 

When fetched into the CPM, each word of 
object code consists of six eight-bit syllables, a 
tag of Oil (which identifies the word as con- 
taining object code), and an odd parity bit. Be- 
cause operators vary in length and because 
they are packed in main memory without re- 
gard for memory word boundaries, to ensure 
operator integrity, separate parity bits are 
generated on each syllable of the program 
code prior to entry of the word into the buffer. 
The parity is checked as the syllables are used. 

The 60-bit program buffer word consists of 
six eight-bit syllables of code, six syllable 
parity bits, three tag bits, an overall parity 
bit, and two error-check bits. (The error bits 
are always set to zero unless the program buf- 
fer word is overwritten by an error word from 
the communications unit.) 

READING FROM THE PROGRAM BUFFER 

To read a location in any of the local 
memory areas in the processor, it is necessary 
only to enter the address into the appropriate 
read pointer register. (Refer to figure III-1-5.) 
The decoding logic then selects the addressed 
word and gates the contents of the location to 
the storage area output as long as the read 
pointer contents remain unchanged. Thus the 
contents of the addressed location are always 
available on the output, and the output can be 
used as needed. 

In the program buffer, two words, one from 
an odd segment and the other from an even 
segment, are addressed simultaneously. This is 
accomplished by using two read pointers. The 
program odd buffer (POB) is the read pointer 
for the odd segments, and the program even 
buffer (PEB) is the read pointer for the even 
segments. 

The two words read simultaneously from the 
buffer storage come from consecutive ad- 
dresses in main memory. One of the words 
contains the beginning of or all of the next op- 
erator to be preprocessed, and the other word 
is the word which was fetched from the next- 
higher memory address. The second word may 
or may not contain syllables of the desired op- 
erator as the operators are of variable length 
and are not restricted to memory word bound- 
aries. 

WRITING INTO THE PROGRAM BUFFER 

When a word of code is ready for entry into 
the buffer storage, it is written into the buffer 
word location (word thru 31) pointed at by 
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Figure 111-1-3. Memory Overlap 
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the five-bit program write pointer (PWP). (See 
figure III-1-5.) 

The two high-order bits are decoded to select 
an eight-word block, and the three low-order 
bits are decoded to select a word location 
within the block. The actual write cycle is 
initiated by triggering a single-shot circuit. 
Each time a valid data word is written into 
the buffer storage, the count in the program 
write pointer is increased by 1. 

The absolute memory address of the next 
word to be placed in the program buffer is 
held in the program upper register (PUR). 

The program lower register (PLR) contains 
the absolute memory address of the first word 
of the block that has been in the program buf- 
fer for the longest time. When the CPM is 
started, the buffer is filled from word thru 
31. Thereafter, each word fetched normally 
overwrites the oldest word resident in the buf- 
fer. 

When the processing of the last two words of 
program code in the buffer begins, the pro- 
gram-buffer logic requests the communica- 
tions unit to fetch the next eight words of code 
from main memory. The PLR contents are 
then increased by eight. 



The branch pointer (BR) identifies with two 
bits which block of the buffer contains the 
word whose address is in the PLR. The BR is 
counted up each time the PLR address is 
changed. 

BRANCHING 

Whenever a branch is executed, the branch 
address is entered into the program address 
register (PAR). Then the PAR contents are 
compared with the contents of the PU and PL 
to determine if the branch is local. If the 
branch address is between the PU and PL ad- 
dresses, the code is in the program buffer. 

For local branches, the read pointers are up- 
dated by determining the offset of the branch 
address from the PLR setting. This offset, to- 
gether with the BR contents, can then be used 
to provide the block and word address of the 
code in the buffer. 

If the branch is not local, excluding branch 
on true (BRTR) and dynamic branch true 
(DBTR), the program buffer is declared empty 
and the address in PAR is transferred to the 
PUR and PLR, then to the communications 
unit as the address for the eijrht-word fetch. 




Figure II 1-1 -5. Program Buffer Unit 
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After the eight-word fetch is received from 
memory, the PU contents are increased by a 
count of eight. The next branch address is 
then compared with the new PU and PL ad- 
dresses. 

For BRTR and DBTR operators, a check for 
loop (CFL) is made to determine if the branch 
is local in the next 4-word code block prior to 
the actual fetch from memory. To do this, the 
hardware increases the PU contents by 4 and 
compares the PAR contents with the contents 
of the PU and PL. 

If the branch address is between the PU 
and PL addresses, the program buffer is de- 
clared empty and the address in PU is re- 
turned to the previous setting, then trans- 
ferred to the communications unit as the ad- 
dress for the eight-word fetch. Thus, the last 
block of code is saved so that branching back 
can be performed locally in the program buf- 
fer. 

If the branch is not local in the four-word 
code block, the hardware performs the branch 
operation as explained in the previous 
paragraph. The CFL condition is released 
when the next change in direction occurs, or 
when an enter, exit, or a return is processed. 

EDIT MODE OPERATION 

The operation of the program buffer is al- 
tered during table edit mode. When the proces- 
sor executes a Table Enter Edit operator, it in 
effect branches to a block of code referred to 
as an edit table. An edit table consists of a se- 
ries of special operators used to edit data. One 
pass is made thru the table each time the ta- 
ble is used. The last operator in the table is an 
End Edit operator. At the completion of the 
table pass, the processor returns to the 
operator following the Table Enter Edit 
operator in the program code string. 

Some of the program code string is main- 
tained in the buffer during the table pass to 
facilitate an orderly return after the edit 
mode operators have been processed. There- 
fore, during edit mode, two blocks of the buf- 
fer are used for edit operators and two blocks 
are assigned for keeping a portion of the pro 
gram code. The program write edit pointer 
(PWE) flip-flops replace the two high-order 
bits of the PWP during edit mode operation. 
These PWE bits are them counted in a manner 
that allows only the two blocks assigned to the 
edit operators to be loaded during edit mode. 
The two high-order bits of PWP remain un- 
changed and are used to reestablish the write 
pointer address on completion of edit mode. 

On entry into edit mode, the PL address is 
adjusted to account for the blocks of program 
code which will be overwritten by edit 
operators, then the updated PL address is 



saved. On exit from edit mode, the PL address 
is reentered into PLR. Then the PL address, 
together with the block (BK) count, is used to 
set up the PU address. (The block counter 
shows how many blocks of program code were 
in the buffer prior to entry into edit mode.) 



VECTOR MODE OPERATION 

Another change in operation occurs when 
the processor encounters vector mode 
operators. Vector mode operators facilitate the 
repetitive execution of an operator or a group 
of operators on all items in an array or a 
group of arrays. When the vector mode 
operators appear in a single word of code, the 
logic simply forces an automatic one-word 
branch backwards until all items have been 
processed. When the vector mode operators ex- 
tend beyond the boundaries of a program 
word, advantage is taken of the automatic lo- 
cal-branch-point detection. 



PROGRAM BARREL 

The program barrel, shown in figure 1 1 1-1-6, 
is a shifting mechanism used for aligning and 
extracting the program operators from the 
two words of code read from the program buf- 
fer. The program barrel consists of one selec- 
tion stage and one shift stage. The selection 
state receives as an input the two program 
words which are being read from the program 
buffer. 

SELECTION GATING STAGE 

The selection gates align the two words read 
from the program buffer so that the word in 
which the beginning (most-significant portion) 
of the next operator appears is placed in the 
more-significant word position, and the other 
word in the less-significant word position. 
When the odd-even flip-flop (OEF) is set, the 
odd word is placed as more significant. When 
OEF is reset, the even word is placed as more 
significant. The OEF flip-flop is complemented 
each time the last syllable of a word is proc- 
essed. 

Only the eight most-significant syllables of 
the two words are provided as an output from 
the selection gates. The four least-significant 
syllables of the word in the less-significant po- 
sition are not required for decoding the 
operator and are stripped off at this point. The 
eight output syllables include at least the 
most-significant syllable of the next operator 
to be processed and the two syllables which 
follow the most-significant syllable. All 
operators can be decoded from this informa- 
tion. 
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BARREL SHIFT STAGE 

The shift stage is used to extract the most- 
significant syllable of the next operator and 
the two following syllables. These three sylla- 
bles are then forwarded as the input to the in- 
struction decode register (IDR). In effect, the 
three syllables are left justified and then ex- 
tracted. The three syllables required are se- 
lected by decoding the contents of the barrel 
select register (BSR). The contents of BSR 
provide the syllable position of the beginning 
of the operator being extracted. The BSR 
count is increased by one when the 24 bits are 

As soon as the operator has been decoded, 
the BSR count is advanced further if the oper- 
ator contains more than one syllable. Each 
time a BSR count cycle (from thru 5) is com- 
pleted, the end of a program word has been 
reached. Then the OEF flip-flop is comple- 
mented. When a branch occurs, both the BSR 
and OEF are force-loaded to properly identify 
the location of the new code in the program 
buffer. The BSR is located in the program con- 
trol unit and is updated under control of that 
unit. 

SYLLABLE PARITY CHECKING 

Separate gating is provided to extract from 
the program barrel the syllable parity bits as- 
sociated with the three selected syllables of 



program code (see figure III-1-6). The 12 parity 
bits from the two words read from the pro- 
gram buffer are applied to the parity gating, 
which uses the OEF and BSR contents to se- 
lect the three desired bits. These parity bits 
are loaded into the IDR parity register (IDP), 
at the same time as the operator syllables are 
loaded into the IDR. 

PROCESSING OF LT48 OPERATOR 

Most of the operators consist of three or less 
syllables. However the LT48 operator has a 
one-syllable operator code in one program code 
word and a 48-bit literal value contained in the 
following program word. The execution of this 
operator consists of placing the 48-bit literal 
value on the top of the stack. Because only 24 
bits are output from the barrel, the 48-bit lit- 
eral value is not available at the barrel out- 
put. However, the LT48 operator code is 
passed thru the barrel, and the 48-bit literal 
value is available at the program buffer out- 
put. Therefore the value is passed to the 
execution unit directly from the program buf- 
fer output. This is accomplished by applying 
both the odd-word and even-word outputs from 
the program buffer to the execution unit's 
data input register (the EWR), then comple- 
menting OEF and using the result to select 
the literal value for loading into the EWR. 
Then, so that the next two words of program 
code are selected during the following 
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operation, the BSR is reset to and OEF is 
complemented once more. 

PROGRAM CONTROL UNIT 

The primary tasks of the program control 
unit (PCU) are to decode the program 
operators and to partition the object code into 



c 



OWR 



TO SU- 



EWR 



a series of micro operators which are placed in 
the appropriate queues for execution. Figure 
III-1-7 is a simplified block diagram of the 
PCU and shows the important operational flow 
and control interconnections. 

Two major registers in the PCU are directly 
in the operator pipeline and constitute two of 
the processing stations in the pipeline; these 
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are the instruction decode register (IDR) and 
the instruction execute register (IER). The 
IDR is the preprocessing or "look-ahead" sta- 
tion of the PCU. The IER holds the operator 
when it is being divided into micro operators 
and is the major execute register of the PCU. 

INSTRUCTION DECODE REGISTER 

As a "look-ahead" station, the IDR is used to 
decode the program operator and to set up 
conditions for PCU execution of the operator 
in the IER. The operator remains in the IDR 
until the PCU processing of the preceding op- 
erator is complete, then the operator in the 
IDR is passed on to the IER and the following 
operator is loaded into the IDR. The 24-bit 
IDR is loaded with the output of the program 
barrel and, by its decodes, in conjunction with 
the IER decodes, controls the output of the 
program barrel. 

The processing functions of the IDR include 
the initiation of stack adjustments to provide 
the proper configuration of operands in the ex- 
ecution unit at the start of each operator, re- 
questing access to other units within the CPM 
when the operator decode indicates that com- 
munication with other units is required, exam- 
ination of the operator following each Name 
Call operator to determine if the Name Call 
and the following operator can be 
concatenated, and initiation of the appropriate 
timing sequence for IER execution of the op- 
erator. 

REGISTERS ASSOCIATED WITH THE IDR 

The control registers associated with the 
IDR are the instruction decode parity (IDP) 
register, the program index next (PN) register, 
the next syllable (NS) register, and the barrel 
select (BS) register. The IDP register contains 
the three syllable parity bits associated with 
the syllables contained in the IDR and is used 
in checking IDR parity. 

The PN and NS registers contain the pro- 
gram index and syllable counts for the 
operator contained in the IDR. The program 
index value, when added to the contents of the 
program base register (PBR), provides the ab- 
solute main memory address of the program 
operator. The syllable count identifies the 
starting syllable position in the memory word 
of that operator. 

The barrel select register, which identifies 
the syllable position of the first syllable of the 
next operator to be placed in the IDR, is up- 
dated in accordance with the decodes from the 
IDR and the IER. The contents of the barrel 
select register controls the output of the pro- 
gram barrel as previously described. 



IDR DECODES 

Decoding of the operator in the IDR provides 
two types of decode signals: control decodes, 
which are used for updating the contents of 
the registers associated with the IDR, and op- 
erational decodes, which are used in the pre- 
processing of the operator in the IDR. 

CONTROL DECODES 

When processing of a new segment of pro- 
gram code string begins, the contents of the 
program base register, which is maintained in 
the address memory area of the address unit, 
are updated to provide the base address for 
the code segment being executed. The memory 
address of each operator in the segment is 
maintained as an index to this base. This pro- 
gram index and the associated syllable count 
are passed along with the operator in the CPM 
pipeline until the execution of the operator is 
complete. 

If some interrupt is encountered in the pipe- 
line, the memory address of the operator is 
thus available for re-execution or error report- 
ing purposes. The program index and syllable 
counts are established in the PN and NS regis- 
ters. The contents of these registers are up- 
dated by IDR and IER decodes as part of the 
preprocessing of each operator. The syllable 
count in the NS register is updated along with 
the BS register contents. Each time an NS 
register cycle, which is a count from thru 5, 
is completed, the PN count is increased by 1. 

The control decode signals from the IDR are 
also used to update the contents of the BS reg- 
ister. The BS register contents are then used 
to control the alignment of the next operator 
coming out of the program barrel. The con- 
tents of the BS register are upcounted by 1 
each time the IDR is loaded. For monosyllabic 
operators, no additional update is required. 

For multi-syllable operators which will be 
held in the IER for only one machine cycle, 
additional updating occurs at the beginning of 
the next machine cycle. However, for those op- 
erators which will be held in the IER for sev- 
eral cycles, additional updating occurs at 
various times, but always quickly enough so 
that the next operator may be in the IDR for 
at least one machine cycle before transfer to 
the IER. 

OPERATIONAL DECODES 

The operational decodes of the IDR contents 
are used primarily for stack adjustments, for 
concatenation investigation, and for gaining 
access to other units as required. 

To facilitate the issuing of micro-operators 
which provide for the proper operand 
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configuration in the execution unit at the be- 
ginning of each program operator, the PCU 
must predict what top-of-stack operands will 
be left in the execution unit at the completion 
of each operator. This prediction is maintained 
in the stack-A-operanci (SKA) and stack-B-op- 
erand (SKB) flip-flops in the PCU. When an 
operator is in the IDR,, the control logic deter- 
mines what the initial operand configuration 
for that operator must be. If the contents of 
SKA and SKB indicate that the top-of-stack 
operands in the EU will not be in the proper 
configuration, then IDR Operational decodes 
are passed to the IER which inserts stack-ad- 
justment micro operators as reauired. 

The purpose of the NAMC operator is to 
place an IRW on the top of the stack. How- 
ever, if the operator following the NAMC re- 
quires that the address couple in the IRW be 
evaluated to derive the memory address, the 
NAMC operator is concatenated with the fol- 
lowing operator, so that the address couple in 
the code string can be converted directly to an 
address. The concatenation occurs whenever 
NAMC is followed by an Enter operator, any 
index operator, DBUN, LOAD, LODT, or store 
operator. The IDR operational decodes are 
used to detect when concatenation may occur. 

Because the NAMC operator contains two 
syllables, the third syllable in the IDR with 
the NAMC operator is the operator code of the 
next operator in the code string. When conca- 
tenation is possible, the operational-decode sig- 
nals set a control flip-flop to denote the action. 

The IDR decodes are also used for access re- 
quests. If the decoding of the operator in the 
IDR shows that a fetch or store operation is 
required for execution of the operator, the 
IDR requests use of the storage unit, so that 
when the operator is in the IER, the PCU may 
queue a request for the required operation. In 
a similar manner, if data is to be provided di- 
rectly by the PCU to the execution unit along 
with the micro operators, or if variant infor- 
mation is to be loaded into the K and L 
queues, the IDR decode signals request use of 
the execution write register (EWR) for the 
PCU. 

INSTRUCTION EXECUTE REGISTER 

The 24-bit instruction execute register is the 
main PCU processing register. The IER is 
loaded from the IDR each time the IER com- 
pletes the PCU processing sequence of the cur- 
rent operator. As the next operator is loaded 
into the IER and decoded, the IER issues any 
required stack-adjustment micro operators to 
the execution unit. Then the IER issues the 
required micro operator sequence to the EU. 



All micro operators issued are placed in the 
OW register in the PCU. The contents of the 
OWR are then written into the execution unit 
operator queue or, if the execution unit is 
waiting for work, are passed directly to the ex- 
ecution unit. The micro-operator codes issued 
to the execution unit are eight bits in length. 
Simple program operators require a series of 
micro-operators to complete the operator func- 
tions. In many cases, the operator code of the 
program operator is issued directly to the 
execution unit as a micro operator. 

The primary timing control signals for PCU 
processing are developed by a down-counter, 
which is preset to the proper configuration 
from IDR decodes. During processing, the IER 
decodes issue a micro operator on each ma- 
chine cycle. Issued along with each micro oper- 
ator are variant codes and, in the case of li- 
terals, data. Variant information and data pro- 
vided by the PCU are loaded into the EWR 
and then queued for EU use. Often the vari- 
ant information supplied to the execution unit 
is taken directly from the second and third syl- 
lables of multisyllable operators. When a micro 
operator requires a fetch or store of data for 
execution, the IER decodes cause the address 
to be queued for storage unit action. 

When the last micro operator of a program 
operator sequence is issued by the IER, the 
PCU sets a special bit in the OW register 
which informs the execution unit that this mi- 
cro operator completes a program operator se- 
quence. 

Many of the micro operators issued by the 
PCU can be executed in only one machine cy- 
cle, others require multiple cycles for execu- 
tion. When micro operators requiring several 
machine cycles are executed, the execution 
unit operator queue may become full. In such 
cases, PCU operation is suspended until space 
is available. 

As previously stated, the program index and 
syllable information remains with the operator 
throughout the execution of the operator. To 
accomplish this, the contents of the PN and 
NS registers are transferred into the PC (pro- 
gram current) and CS (current syllable) regis- 
ters at the same time as the associated pro- 
gram operator is transferred from the IDR to 
the IER. Then, each time a micro operator is 
issued, the contents of the PC and CS registers 
are queued along with the micro operator for 
execution unit use. 

PREPROCESSING OF VALUE CALL AND NAME 
CALL OPERATORS 

The Value Call and Name Call operators are 
the most frequently used operators in the 



3-13 



B 7700 operator set. Therefore, special process- 
ing features are provided to facilitate one-cy- 
cle execution of these operators. 

The two-syllable Value Call instruction 
(VALC) requires that the 14-bit address couple 
in the instruction be evaluated to provide an 
absolute address from which data are fetched 
and placed on the top of the stack for EU use. 

The two-syllable Name Call instruction 
(NAMC) indicates that the address couple in 
the instruction may be used to form an IRW, 
which is then placed on top of the stack. How- 
ever, if the NAMC operator is followed by an 
operator which would require evaluation of 
the address couple to derive an absolute ad- 
dress, then the NAMC is concatenated with 
the following operator and the address couple 
is evaluated immediately. NAMC is 
concatenated when the next operator in the 
program code string is any of the following: 
ENTR, INDX, NXLN, NXLV, STOD, STON, 
OVRD, OVRN, DBUN, LOAD, and LODT. If a 
NAMC cannot be concatenated, an IRW con- 
taining the address couple is placed on the top 
of the stack for EU use. 

The 14-bit address couple in the NAMC and 
VALC instructions consists of a lexicographic- 
level field (LL) and an index field (I). As 
shown in figure III-1-8, the length of each of 
these fields varies with the current lexic level 
of the active program. The LL field ranges 



from one to five bits in length and contains 
only as many bits as are required to define the 
current lexic level. The remaining bits are the 
index field. (The bits of the LL field are in in- 
verse order so that the least-significant bit of 
the field is located in the most-significant bit 
position of the address couple.) 

To facilitate preprocessing of VALC and 
NAMC, the PCU presupposes that every oper- 
ator in the code string is either a NAMC which 
can be concatenated or a VALC. Therefore, as 
each operator is loaded into the IDR, it is as- 
sumed to contain an address couple which 
must be converted into an absolute address. If 
subsequent decoding reveals that no address- 
couple conversion is required, or that there is 
no address couple in the operator, the conver- 
sion is terminated with no loss in processing 
speed. 

When any operator is transferred from the 
program barrel to the IDR, bits 21:5 of the 
barrel output, which contain all possible bits 
of the LL field of the address couple (if the op- 
erator is a VALC or a NAMC), are gated with 
a lexic-level mask in addition to being entered 
intact into the IDR. The lexic-level mask gates 
the LL field bits of the address couple and in- 
hibits any bits which are part of the index 
field. The lexic-level mask is set up by decod- 
ing the current program lexicographic level, 
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Figure 111-1-8. Address Couple Bit Assignment 
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which is maintained in the lexic level (LL) reg- 
ister. The output of the LL mask, then, is the 
bits of the LL field if i;he operator is a NAMC 
or a VALC. In any event, these bits are loaded 
into the five LS bits of the program read 
pointer in the address unit. 

If no request for use of the AU is pending, 
the contents of the display register addressed 
by PRP are read out of the address memory 
area and entered into the display read regis- 
ter. The LL field, now in PRP, is also written 
into the lexic level write register (LLW) for 
possible later use. 

By this time, the decoding of the operator, 
now in the IDR, is complete. If the operator is 
either a VALC or NAMC, it contains an ad- 
dress couple and the LL field is not trans- 
ferred to the IER with the rest of the 
operator, but is stripped out of the operator 
code by use of the lexic-level mask. Therefore 
when a NAMC or VALC operator is trans- 
ferred into the IER, bits 20:13 of the IER (the 
largest possible index field) contain only index 
bits from the address couple. These bits are 
now applied directly to the address-adder se- 
lection gates in the address unit for use as one 
of the inputs to the adder. The other input is 
the base address now contained in the display 
read register. Therefore, the adder output is 
the absolute memory address described by the 
address couple. 

For a Value Call, the output of the address 
adder is gated into the input register of the 
storage unit, along with the PCU request for 
a fetch and the EU-data-queue address re- 
served for the requested data. This informa- 
tion is then queued for storage-unit process- 
ing. The same operation is performed for a 
concatenated Name Call which requires a 
fetch operation. (NAMC concatenated with an 
index-type or Enter operator requires a fetch 
operation.) For a name call-store combination, 
the address and a request for a store are 
queued for storage-unit action, but the store is 
not performed until the EU supplies the data 
to be stored. 

For an unconcatenated Name Call, the out- 
put of the address adder is ignored, and an 
IRW is built in the EWR. The address couple 
for the IRW is formed by combining the index 
value in the IER with the LL field, which was 
saved for this purpose in the LLW register. 

ADDRESS UNIT 

The address unit (AU) contains the logic nec- 
essary for the calculation of absolute ad- 
dresses, both directly as in Value Call and in- 
directly as in pointer update for string 
operators. As shown in figure III-1-9, the func- 



tional parts of the address unit are the display 
write (DW) register, the display read (DR) reg- 
ister, the address adder, the address-storage 
area, and the read and write pointers (PRP, 
ERP, and DWP) for the AU local storage. The 
address unit is not directly in the processing 
pipeline and is therefore not queue driven. It 
is an autonomous unit only to the extent that 
a write cycle into the address-storage area 
need only be initiated and not completely con- 
trolled by the initiating unit. 

The local address-storage area comprises 48 
locations, each location having 20 bits for stor- 
age of an absolute address and two bits for 
storage of address residue. The local storage 
contains the 32 display registers used in 
relative addressing within the active program 
stack. Each display register in use contains 
the absolute address of the MSCW for a differ- 
ent lexicographical level. The display registers 
are numbered in order from DO thru D31; the 
DO register contains the MSCW address for le- 
xicographic level 0, the Dl register contains 
the MSCW address for lexicographic level 1, 
etc. To address within any level, the appropri- 
ate D register contents are read, and then the 
displacement of the desired item from the 
MSCW is added to the MSCW address to pro- 
vide an absolute address for the required item. 

The remaining 16 locations of the storage 
area provide storage for certain index, base 
and miscellaneous registers. The registers 
maintained in these locations are as follows: 



Register 


Register Name 


Mnemonic 




SIR 


Source Index Register 


MR 


Destination Index Register 


TIR 


Table Index Register 


BOSR 


Base of Stack Register 


S1LS 


Scratch (Space Local Storage) 


PBR 


Program Base Register 


SBR 


Source Base Register 


DBR 


Destination Base Register 


TBR 


Table Base Register 


SNR 


Stack Number Register 


PDR 


Program Dictionary Register 


S2LS 


Scratch (Spare Local Storage) 


ADZ 


Alternate DO register 


APIR 


Alternate Program Index Register 


ALL1 


All l's Register 


LD1 


Last D [ 1 ] used as SD1 base 



All the contents of the address storage are 
addressable by the SPRR and RPRR 
operators. (A total of 64 registers are address- 
able by these operators, 48 of which are in the 
AU address storage area. Those registers 
which are addressable but which are not con- 
tained in the AU address storage are also ad- 
dressed by use of the read and write decode 
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Figure 111-1-9. Address Unit 



circuits of the address unit.) 

The display write (DW) register, buffers in- 
formation being written into the address-stor- 
age area so that the controlling logic can re- 
lease immediately instead of waiting for the 
storage cycle to complete. Residue of the ad- 
dress being written is checked when the ad- 
dress is contained in the DW Register. The DW 
register is also used as one of the two adder 
inputs. In addition, it serves as an accumula- 
tor when more than one adder cycle is re- 
quired. For example, in string processing, two 
adder cycles are required when adding the in- 
dex, a constant, and a base to derive an ad- 
dress. 

All writing into the storage area is con- 
trolled by either the E'U or PCU, but the DW 
register may be loaded by the EU, or PCU 
when its contents are to be used as an adder 
input. The DW register contents are written 
into the storage only when a write decode se- 
lects a storage location and a write strobe is 
generated by the AU control logic. 

The DW register can be loaded in true or 
complement form so the adder may be used for 
addition or subtraction. Subtraction is used 
when performing limit comparisons. 

The display read (DR) register is the output 
register of the address -storage area. The DR 
register contents are always an input to the 
address adder. The DR register is always 
loaded with any information read from the ad- 
dress-storage area. When a limit comparison is 
required prior to a write cycle, the DR can be 
used to buffer the contents of the limit regis- 
ter so that the write cycle may be initiated 
while the add cycle for the limit comparison is 
in progress. 

For write operations, the hexadecimal ad- 
dress of the addressable register is entered di- 
rectly into the six-bit display write pointer.. 
The write-decode circuitry then selects the ap- 
propriate storage location and the write cycle 
commences. For addressable registers not con- 
tained in the address-storage area, the decode 
logic selects the appropriate data paths to fa- 
cilitate updating the addressable register. 

There are two read pointers, the PRP which 
is used exclusively by the PCU, and the ERP 
which is used exclusively by the EU. Because 
either the EU or the PCU may request a read 
operation by loading the appropriate read 
pointer, priority-selection logic is required to 
resolve access conflicts. In general the PCU 
has priority, but must release the AU after 
one cycle. The EU has priority when the PCU 
is in a hold condition and can maintain control 
of the AU until it has finished any required 
operations. 



Access to the AU is granted by the control 
logic. Like the write pointer, the read pointers 
are loaded with any address of an addressable 
register. If the address is in AU local storage, 
a read cycle occurs and the contents of the ad- 
dressed register is subsequently loaded into 
the DR register. When an addressable register 
not in local storage is read, the contents of the 
register are gated to the execution unit by the 
read-decode logic. 

The two-input address adder adds the con- 
tents of the DR register to the contents of ei- 
ther the DW register or a value (such as a dis- 
placement for Value Call) inserted directly 
through the selection logic from the PCU. 

The adder output may be routed to the EWR 
in the EU; to the F, S, or LOSR in the stack 
buffer; to the MAR or SIR in the storage unit; 
to the PA or PIR in the PCU, or to the DW 
register for use in a subsequent adder cycle. 

The AU control logic monitors the output of 
the adder to detect adder overflow, all bit re- 
sults, or the results of adder comparison. 

The AU control logic provides the timing 
and control signals necessary for operation of 
the AU. The basic operations performed by the 
AU include a read cycle, a quick-write cycle, 
and a read-add-write cycle. 

The read operation is performed in two ma- 
chine cycles. During the first cycle, the con- 
tents of the addressed location are read, and 
during the second cycle the information is 
routed thru the adder, combined with any 
other input selected to the adder, and the re- 
sult is routed to the appropriate destination. 
For example, in address calculation for Value 
Call, the appropriate I) register is read, the 
displacement is added to the contents of the D 
register, and the result is sent to the SIR to be 
queued for SU action. 

The quick- write cycle is used by the EU to 
update information in an addressable register. 
The two-cycle operation consists of a load cycle 
and a write cycle. 

The read-add-write cycle is used to modify 
the contents of an address-storage location 
when the modification is based on the current 
contents of the location. The operation is per- 
formed in three cycles. 

EXECUTION UNIT 

GENERAL 

The execution unit (EU) is the final stop in 
the processing pipeline. The great majority of 
instructions are not completed until the execu- 
tion unit has processed the instruction. The 
execution unit is the only unit in the processor 
which operates on value data. It also has some 
control word formation and address calcula- 
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tion responsibilities. This unit includes storage 
for the two top of stack operands, A and B, 
and may temporarily store parts of character 
strings on which it is operating. The pipeline 
processing technique is implemented further 
in the EU. There exists within the EU, three 
distinct processing stations: an operator level, 
a command level, and a store level. 

INPUT QUEUES 

The execution unit like the program control 
unit is queue driven. All operations and 
operator associated data are placed into the 
queues of the execution unit by the program 
control unit. The value data inputs are sup- 
plied by the storage unit or the communica- 
tions unit. Since the queues are implemented 
by memory chips, simultaneous read and write 
can take place. The purpose of each of the var- 
ious EU input queues is described in the fol- 
lowing paragraphs. 

OPERATOR QUEUE 

The operator queue (QQ) is the storage area 
for micro operators pending EU processing. 
The use of the queue allows the PCU and the 
EU to operate independently. Information to 
be written into the operator queue is placed in 
the order-code-write register (OWR). The PCU 
loads the OWR, then initiates the write cycle. 
The micro operator and control information in 
the OWR are then written into the address se- 
lected by the contents of the operator-queue 
write pointer (OQW). Following the write, the 
OQW count is advanced. The operator queue 
contains eight 12-bit locations; each location is 
loaded with the following information: 

a. Bits thru 7 contain the micro operator 
code. 

b. Bit 8 (END) is set if this micro operator is 
the last in a program operator sequence. 

c. Bit 9 (RPT) is the report bit, which when 
set, directs the EU to notify the PCU when ex- 
ecution of the micro operator is complete. 

D. Bit 10 (ESB) when set, indicates that the 
B operand location will contain data at the 
start of the micro operator execution. 

e. Bit 11 (ESA) when set, indicates that the 
A operand location will contain data at the 
start of the micro-operator execution. 

The operator queue is read only by the EU. 
The contents of the operator-queue read point- 
er (OQR) provide the queue address for the 
read operation. The read address is updated 
when the EU is executing the last routine of 
the previous micro operator if the queue is not 
empty, no hold condition exists, and the EU is 
not generating a micro operator. When the ad- 
dress is updated, the new information becomes 
immediately available at the output of 
operator queue. When the output of the 



operator queue is to be used, the micro- 
operator information is entered into the EU 
operator registers* 

EU DATA QUEUE 

The EU data queue (DQ) is an eight-word IC 
local storage area organized as four two-word 
groups. The purpose of the data queue is to 
buffer data generated by the PCU preproces- 
sing (look-ahead) logic. Literals, Value Calls, 
and concatenated operators cause space to be 
reserved, and, in the case of literals, data to be 
entered. Each of the four group locations has 
a validity bit associated with it. When the data 
from a look-ahead fetch becomes available, the 
storage unit places it in the reserved data- 
queue location, and sets the associated group 
validity bit. The second word of each group is 
loaded with the second-half (least-significant 
portion) of double-precision operands, or, in 
the case of a non-present data descriptor, with 
the absolute address from which the descrip- 
tor was fetched. For single-precision words 
other than non-present data descriptors, the 
second word location in the group is left emp- 
ty. 

Writing into the data queue is performed by 
the PCU, the storage unit, or the communica- 
tions unit. Reading from the data queue is 
performed by the EU only. 

DATA QUEUE WRITE OPERATION 

The input register for the EU data queue is 
the EU write register (EWR). When a write cy- 
cle is initiated, the contents of EWR are en- 
tered into the address selected by the write 
pointer (DQW) and flip-flop WLSQ. The data 
group to be loaded is selected by decoding the 
contents of DQW, and WLSQ selects which of 
the two word locations in the group is to be 
loaded. (The first word of the two word group 
is loaded when WLSQ is reset.) 

The PCU keeps track of the next group to be 
filled by use of the data queue assignment 
(DA) counter. When the PCU encounters a lit- 
eral value, it loads the value into EWR, trans- 
fers the DA count into DQW, initiates the 
write cycle, and then advances the count in 
DA. 

When an operator requires data not con- 
tained in the program code string, the PCU 
posts in the storage unit operations queue a 
request for the data together with the main 
memory address of the data and the contents 
of the DA counter. Then the PCU advances 
the DA count, thus reserving space for the re- 
quested data. When the storage unit or the 
communications unit obtains the requested 
data, the word is entered through the EWR 
into the reserved data-queue location. 

In order that the EU may know when a 
group location has been loaded and whether a 
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single precision operand has been written into 
the group location, there are separate data- 
queue-valid (DQV) and queue-single-precision 
(QSP) flip-flops associated with each data- 
queue group location. 

When a look-ahead fetch is performed by ei- 
ther the SU or Comm Unit, the QRL (queue 
read lookhead) flip-flop is set. Excluding cer- 
tain conditions, the QRL, when set, allows the 
EU to perform an early evaluation of the tag 
information in the EWR while writing the 
EWR contents into the data queue. (The 
evaluation of tag information determines what 
action should be taken to process the fetched 
item.) An early tag evaluation can not be per- 
formed when an item in the EWR is identified 
as a non-present descriptor, DP operand, or 
has a tag of 2, 4, 6, or 7. 

DATA QUEUE READ OPERATION 

The EU reads the information from the data 
queue in the same order in which the PCU re- 
served the group locations. Read addressing 
for the data queue is accomplished by decod- 
ing the contents of the data-queue-read (DQR) 
pointer, which selects the group to be read, 
and of flip-flop RLSQ, which identifies which 
of the two words in the group is to be read. 
The contents of the word location selected by 
DQR and RLSQ are available on the queue 
output lines. To use the information, the EU 
simply gates the information onto the T bus. 
The EU will not attempt to use the informa- 
tion until the associated DQV bit is set. 

EU LOOK-AHEAD DATA QUEUE 

The control information provided with each 
group written into the EU data queue is also 
entered into an EU look-ahead data queue (EL 
queue). This control information includes a 
copy of bits 45 thru 50 of the data being en- 
tered into the data queue and a bit which indi- 
cates if the associated data-queue word is in 
integer form. 

The look-ahead information is addressed by 
the data-queue read pointer, but the address 
decoding is such that the look-ahead informa- 
tion is available at the EL queue output when 
the preceding data-queue group is being ad- 
dressed. The look-ahead information is also 
used to determine what commands should be 
called to process the associated operands. 
K AND L QUEUES 

The K queue (KQ) and the L queue (LQ), 
which are used in conjunction with the 
operator queue, contain coded variant infor- 
mation for use in execution of the related mi- 
cro operator. The K and L queues each contain 
eight 10-bit locations. The operator variant 
codes are eight bits in length, and in the other 
two bits of each location residue is maintained 
on the variant code. Usually the variant infor- 



mation supplied with a micro operator is taken 
directly from the second or third syllable of 
the program operator in the IER. Such 
variables could be used to identify the length 
of a selected field or a bit location in a word. 
In other cases, the variant information is gen- 
erated by the PCU to alter or further define 
the related micro operator. 

Addressing of the K and L queues for both 
read and write operations is accomplished by 
use of the operator queue read and write 
pointers.. Therefore, each time an entry is 
made into the operator queue, an entry is also 
made into the K and L queues although this 
information may be all bits. Likewise, when 
an operator-queue location is addressed by the 
read pointer, the associated locations in K and 
L are also addressed. 

The first 16 bits of EWR are used as the in- 
put register for the K and L variant informa- 
tion. The variant-residue (VNR) register in the 
PCU supplies the residue for K, but the 
residue for L is written directly into the queue 
from the PCU residue generator. 

The outputs of the K and L queues are en- 
tered into the K and L registers in the EU. 
Like the operator register, the K and L regis- 
ters may be loaded directly from the PCU if 
the queue is empty. 

PIR AND PSR QUEUE 

The PIR and PSR queue (PQ) contains the 
PIR and PSR values associated with the micro 
operators in the operator queue. (The PIR and 
PSR, together with the contents of PBR, iden- 
tify the absolute address and starting syllable 
position of the associated program operator.) 
The PIR queue is loaded with the contents of 
the program current and current syllable reg- 
isters. The PIR queue is written into at the 
same time as is the operator queue and uses 
the same write pointer (OQW) for addressing. 

A separate read pointer PQR is used for the 
PIR queue. The PQR is counted in a manner 
which causes the PIR and PSR information as- 
sociated with each micro operator to be avail- 
able at the output of the PIR queue when the 
micro operator is at the store level of execu- 
tion in the EU. 

Usually the output of the PIR queue is not 
used. However, when the EU starts interrupt 
processing, the output of the PIR queue may 
be gated into the PN and NS registers to pro- 
vide the PSR and PIR values associated with 
the program operator being re-executed. 

LEXIC LEVEL QUEUE 

This queue (LLQ) contains either the lexico- 
graphical addressing level of a particular oper- 
ator in the operator queue or the value which 
was in the PCU display read pointer (PRP) 
when the associated micro operator was in the 
IDR. 
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The current lexicographical level is written 
into the queue any time the PCU processing 
sequence for an operator includes timing 
count Phase 9 (PH9). The PRP read pointer 
value is entered into the queue when either a 
Name Call (NAMC) or Value Call (VALC) oper- 
ator is processed by the PCU. For all other op- 
erators, no entry is made in the queue. 

The information in the LL queue is then 
available at the output of the queue for use by 
the EU during the execution of the related mi- 
cro operators. 

Writing into the LL queue is accomplished 
by use of the operator queue write pointer 
(OQW), and reading from the queue is accom- 
plished by use of the PIR queue read pointer 
loaded into the IDR. (PQR). 

MAJOR EU DATA CIRCUITS 

As shown in figure III-1-10, the EU contains 
five full-word data registers, three data buses, 
local storage areas, and adder and shifting 
mechanisms. These data circuits are described 
in the following paragraphs. 

ADDER 

The most obvious major item required by the 
execution unit is a fast adder. The adder used 
comprises a single-carry-save adder which 
drives a carry-propagate adder. The adder 
fully propagates all carries each time it is 
used, employing a high-speed carry look-ahead 
technique. 

To accommodate all single-precision mantis- 
sas, the mantissa portion of the adder is 39 
bits wide with an extension for multiply and 
divide. This portion of the adder has three in- 
puts. During multiply, two of the inputs are 
used to insert selected multiples of the multi- 
plicand, and the third input inserts the accu- 
mulated product. By this method, six bits of 
the multiplier are calculated on each adder 
pass. The separate, seven-bit exponent adder 
is included to facilitate single-precision, float- 
ing-point arithmetic. 

The adder is also used to perform double- 
precision arithmetic. This is accomplished by 
buffering the double-precision operands and 
intermediate results in the local EU memory 
area. 

The adder provides an efficient means for 
executing logical operations. The single-sum 
and single-carry outputs, which are developed 
for ea« * bit position by the first stage of the 
adder, are selectively gated to derive the 
logical AND, OR, and EXCLUSIVE OR func- 
tions. 

The adder output is checked for residue or 
continuity errors. If either input to the adder 
is invalid, a continuity error occurs. If the sum 



is incorrect, a residue error is detected. 
Separate residue is maintained on the expo- 
nent and mantissa during floating point arith- 
metic operations. 

SHIFT MECHANISM 

The barrel switch is a 48 bit wide, end- 
around shifting mechanism. It is capable of 
shifting by any number of bits from to 47, to 
the left. The barrel output is gated with en- 
abling logic, which allows any number of bits 
from thru 48, out of the barrel, from the left 
or the right. 

The barrel has three shift stages. The first 
stage shifts the input data by multiples of 12, 
the second stage shifts the input by multiples 
of 3, and the third stage shifts the input by 
multiples of 1. The multiples are selected by 
the contents of the shift register in which two 
bits are used to define the selected multiple 
for each shift stage. The shift amount, coded 
in successive bit values of 1, 2, 3, 6, 12, and 24, 
may be entered into the shift register in either 
true or complement form. When this amount is 
loaded in complement form, a right shift effec- 
tively occurs; when loaded in true form, a left 
shift is executed. 

The barrel output gating enables a field of 
any selected length or the entire word to be 
extracted from the barrel. The allow register 
contents determine the number of bits to be 
extracted at the barrel output. Additional gat- 
ing allows this field to be selected either right 
or left justified. 



If either the allow register or the shift regis- 
ter was not loaded when the barrel is used, the 
output of the barrel is declared invalid and a 
continuity error is subsequently detected. Res- 
idue is maintained on the contents of both the 
shift and allow registers. A residue error in 
the contents of these registers results in the 
detection of an EU residue error. Residue is 
also maintained on the data transferred 
through the barrel. If the barrel output has a 
residue error, an EU residue error condition is 
detected. 

LOCAL MEMORY 

The execution unit also includes a local mem- 
ory for storage of the top of stack operands, 
character strings and intermediate results. 
Memory chips are again used for this purpose. 
Parity is maintained on each word in the oper- 
and storage, except for DP arithmetic, and the 
parity is checked each time a word is read 
from local storage. The local memory is split 
into two parts in order to be able to read two 
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words simultaneously. The larger part is called 
the operand storage; the smaller part is called 
the auxiliary storage. The memory space is al- 
located as follows: 

Operand Storage (52 bits wide) 

1. A/B space 0: Two alternate double-preci- 
sion locations. 

2. A/B space 1: Two alternate double-preci- 
sion locations. 

3. R space: Four words. 

4. W space: Four words, which is some- 
times used as two alternate locations of two 
words each. 

Auxiliary Storage (49 bits wide) 

1. H: one word. 

2. J: one word. 

3. Bad C: one word. 

The time required to cycle the memory chips 
is comparable to the time required to 
propagate the worst case carry through the 
adder, so the memory fits neatly into the over- 
all timing scheme. To maintain the fastest pos- 
sible single precision execution times, single- 
precision operands are buffered in the adder 
and barrel input registers rather than in oper- 
and storage. 

The purpose for having alternate locations 
for A and B is to be able to form a new A or 
B without destroying the original input oper- 
ands. This is desirable for diagnostics and er- 
ror recovery. Two values for the A and B oper- 
ands are maintained in storage during the ex- 
ecution of each program operator. The con- 
tents of the A and B operands at the start of 
the operator are held unchanged in the initial 
allocation area, while the current allocation 
area is successively loaded with the current 
values of the operands. When the final result 
of the program operator is obtained, the allo- 
cation is interchanged, so that the final copies 
of the current operands are designated as the 
initial configuration for the next program op- 
erator. 

The adjustment of the memory allocation is 
controlled by use of the EU allocation flip- 
flops. These allocation flip-flops also facilitate 
rapid execution of stack related operators. 

When three top-of-stack operands must be 
maintained in the EU, as during execution of 
the Rotate Stack operator, the W storage area 
is used to maintain the third top-of-stack item. 

DATA REGISTERS 

The execution unit includes five full-word 
data registers (C, D, E, F, and G registers). 



The A and B words of the B 7700 are imple- 
mented in the EU operand storage, as previ- 
ously described. Intercommunication between 
the data registers is carried out by the use of 
three data transfer buses (T bus, S bus, and X 
bus). 

There is one register which loads the oper- 
and storage, and which is the EU output regis- 
ter for communication with the rest of the 
processor. This register is the C register. All 
data error checking, as well as parity and 
residue generation is accomplished when a 
data word is in the C register. 

The D register is the only barrel input regis- 
ter. Any data entered in the D register is im- 
mediately shifted by the barrel and allowed 
out of the barrel, in accordance with the con- 
tents of the shift and allow registers. Because 
the D register is the only barrel input no selec- 
tion gating is necessary. 

Because the adder is used often, it is espe- 
cially important that the delay between the 
registers and the adder be minimized. This is 
accomplished by transferring the contents of 
the adder-input registers into the adder with 
no selection gating. Therefore certain regis- 
ters, namely the E, F and G registers, are ded- 
icated as adder input registers, and actual 
adder selection is accomplished at the input to 
these registers. The E register has special sig- 
nificance in that it is the accumulator, while 
the F and G registers supply new inputs. The 
E and F registers also have six-bit exponent 
fields which are inputs to the exponent adder. 

Unless the contents of these data registers 
are specifically "held", the contents must be 
transferred during every machine cycle or the 
word will be marked invalid. Therefore to 
maintain validity of the A and B operands 
when they are not being used for processing, 
the E register and T bus are often assigned to 
keeping the A operand valid, while the F regis- 
ter and the S bus are assigned to keeping B 
valid. 

DATA TRANSFER BUSES 

Placing the outputs of the adder, the barrel, 
the registers, and the operand storage onto 
buses which go to the registers (which in turn 
are the inputs to the adder, barrel and oper- 
and storage) is the fastest way to transfer 
data without using excessive amounts of hard- 
ware. The data transfer buses, which consist 
of multiple input OR gates, are designed to 
match the stack type features of the simple 
operators and the micro operators. This ap- 
proach led to the implementation of two major 
data transfer buses, one serving as the top 
element of the "bus stack" and the other serv- 
ing as the second element. In simple 
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operations on single precision data, the A op- 
erand is on the T (top) bus, and the B operand 
is on the S (second) bus. During complex oper- 
ations, data segments will be moved onto the 
T and S buses as inputs for micro operators 
commands. 

The processing requirements of simple and 
micro operators suggest particular data paths 
for the buses. In particular, each bus must go 
to those registers which give the bus access to 
the adder, the barrel, the operand storage, and 
areas external to the execution unit. Inputs to 
the stack go to the top position so the operand 
input (for Value Calls, Literals, etc.) from the 
data queue or queue input goes to the T bus 
only. 

Arithmetic results are left in the top posi- 
tion, so the adder output goes only to the T 
bus. The extension of the stack (stack buffer) 
goes to the S only to handle stepping up ("pop- 
ping") the stack. When executing a monadic 
operator with both A and B full initially, it is 
desirable to load B back onto the S bus at the 
end of the operator, so the operand storage 
output is routed to the S bus. However, it is 
also desirable that the inputs to the "bus 
stack" for micro operators go to the top posi- 
tion so the operand storage also goes to the T 
bus. Field results are left in the top position, 
so the barrel output is applied to the T bus. 
Certain other paths to the buses are available 
in order to hold operands on the buses or to fa- 
cilitate particular algorithms. 

Various special paths from the buses to the 
registers exist to speed up multiply and divide 
and these special paths are also useful for 
scale left and scale right. There is one other 
special path, called the X (auxiliary) bus, 
which is not part of the "bus stack". The X 
bus is used during multiply and other extend- 
ed arithmetic calculations to speed up these 
computations. During multiply, the X bus 
transfers to the adder registers a quantity 
equal to three times the multiplicand. 

MAJOR EU CONTROL CIRCUITS 

Figure III-l-ll shows the major EU control 
circuits. These circuits include the operator 
and command registers; the K, L, and R regis- 
ters; A, B, and W control registers, and the A, 
B, R, and W pointer registers. 

The A and B control registers are used to 
maintain ready access to the control informa- 
tion provided with the A and B operands. Such 
information includes the tag bits, the sign bits, 
and a bit which indicates if the related data is 
in integer form. When three top-of-stack oper- 
ands are maintained in the EU, the W control 
register is used for the control bits of the third 
operand. If during execution of an operator, 



the control information may be altered, the 
contents of these control registers are de- 
clared invalid until the updated information 
can be loaded from the C register. The regis- 
ters are initially loaded as the data becomes 
available to the EU. 

The pointer registers (AP, BP, RP, and WP) 
are used for addressing a particular segment 
of a word contained in the EU local storage. 
To extract part of a word from EU local stor- 
age, the pointer contents are decoded to pro- 
vide a word address and a digit location within 
the word. The word portion is used for reading 
the proper word from operand storage and the 
digit information is used in setting up the 
shift and allow registers so that the desired 
segment can be extracted by use of the barrel. 
For repeated operations, the contents of the 
pointer register is updated by use of a special 
adder, and the updated contents are then 
loaded back into the pointer for use on the 
next cycle. 

The K and L registers receive the variant in- 
formation from the K and L queue, or, for dy- 
namic field operators, from the C register. The 
information in K and L may be decoded or, for 
field operators, may be routed thru the K-L 
adder, to provide information for extraction of 
a desired field. The output of the K-L adder is 
K-L+l, therefore in field and bit operators 
when K contains the starting bit, and L con- 
tains the length, the K-L adder output gives 
the shift amount required to right justify the 
desired field in the barrel, and the L register 
contents provide the input for the allow regis- 
ter. 

When the K register contains the scale value 
for scale operators, the amount in K is trans- 
ferred through the K-L adder to the R regis- 
ter. The R register is a repetition counter. For 
scale operators, after each cycle, the count in 
R is decreased by use of the subtract logic and 
the difference is loaded back into R until the 
operation is complete. The R register also 
serves to check the binary value of the K-L 
adder output. (Effectively, this conversion con- 
sists of dividing the binary input by three, 
then placing the remainder as the two least 
significant bits of the quotient.) The conver- 
sion of K-L and L values are loaded into SH 
and AL. 

The remaining major control registers, the 
operator registers and the command registers 
are the primary control registers of the EU. 
The operator registers are used to decode the 
micro operators and the command registers 
are used to generate the data transfer signals 
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for execution of the micro operators. The use 
of these registers is described in the following 
paragraphs. 

BASIC EU OPERATION 

As previously described, the EU does not op- 
erate on basic program code (program 
operators), but rather it executes micro 
operators forwarded to it by the PCU. One or 
more micro operators are executed in complet- 
ing each program operator. The major advan- 
tage in this method is that many program op- 
erators are quite similar in execution, so that 
the same micro operator may be issued for a 
group of program operators. 

The micro operators are grouped by function 
into four families: the: arithmetic family, the 
string family, the control word family, and the 
word family. To simplify micro operator decod- 
ing, separate operator and command registers 
and separate timing counters are provided for 
each micro-operator family. The fifth and 
sixth bits of each eight-bit micro-operator code 
identify the family to which the micro 
operator is assigned. 

When a micro operator is read from the op- 
erator queue, it is entered simultaneously into 
each of the four operator registers. However, 
the fifth and sixth bits of the eight-bit micro- 
operator code are not loaded into the operator 
registers, but are decoded to enable the use of 
only the appropriate operator register. At this 
point, the timing counter for the selected 
family is also enabled. The micro operator is 
decoded, and the first of a sequence of 
operator commands is generated. One coded 
command is entered into the appropriate com- 
mand register at each count of the timing 
counter. Each command is held in the com- 
mand register for only one machine cycle, dur- 
ing which the command is decoded. 

The use of command registers allows groups 
of sub-commands to be generated as efficient- 
ly as possible. The sub-commands are data 
transfer and control signals. The command 
register generation of these data transfer sig- 
nals determines the use of the data registers 
and data bus networks in the EU. The signal 
which loads a command into the command reg- 
ister is also used to route the information 
from the data buses to the data registers. 

On the next effective clock, the command de- 
code causes the necessary transfers of the 
data units thru the selected logic (such as the 
adder or the barrel shifting mechanism) to the 
data buses. Because the command registers 
are loaded with a new command on each effec- 
tive clock, on a given clock, one command is 
loading the buses while the next command is 



selecting the buses to the registers. The only 
requirement for compatibility between the two 
commands is that the resulting bus configura- 
tion of the first command is compatible to the 
input bus requirements of the next command. 
(The "bus configuration" refers only to the 
presence or absence of data on each bus.) 

For example, if data in the E and F regis- 
ters were to be added by one command and the 
next command required that the sum be 
routed thru the barrel shifting mechanism, 
then the command decode of the first would 
generate a data transfer signal which would 
route the adder output to the T bus, while the 
signal which loads the second command would 
simultaneously cause the contents of the T 
bus to be routed to the barrel input register (D 
register). 

The next effective clock would then load the 
second command, while the sum on the T bus 
would go to both the D register for use in the 
second command and, automatically, to the C 
register for error checking and for storage of 
a copy of the result of the add operation. This 
automatic routing of the results of each com- 
mand to the C register is the "store-level" ac- 
tion required for each command. 

When the contents of the C register are to 
be transferred (unloaded) to a location other 
than EU local storage (such as transfer to the 
SU, the AU, or some EU register), the transfer 
is controlled by a coded store-level command 
entered into the store (ST) register. 

The execution of each micro operation en- 
tails the processing of a series of one or more 
commands. However, although the enabled 
command register is loaded with a new com- 
mand on each effective clock, not all of these 
commands are issued by the decode of the mi- 
cro operator in the operator register. 

Each command register is allowed to reload 
itself with successive commands when a 
natural unit of actions requires a certain se- 
quence of commands. Such a sequence of com- 
mands is called a routine. At the end of the 
routine, the operator register is allowed to 
load the command register and the timing 
count is advanced. The command load for the 
last command of a routine generates a final- 
command signal, which enables the operator- 
register output and the timing count. 

For each micro operator, when the last com- 
mand generated by the operator-register de- 
code logic is loaded to the command register, 
the operator-level signal, final routine, is pro- 
duced. When the final-routine signal has been 
generated, the operator register is loaded with 
the next micro operator from the operator 
queue. 
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The last micro operator of each program op- 
erator is specially tagged by the PCU. When 
this micro operator has been fully executed, 
the EU prepares for the next program 
operator. This preparation consists of checking 
for interrupts and of switching the allocation 
of the EU local storage areas so that the final 
stored results of this program operator are 
designated as the initial A and B configura- 
tion of the next program operator. During 
execution of this next program operator, this 
initial operand configuration will be saved, 
while the current A and B operands are repea- 
tedly entered into the alternate A and B stor- 
age locations. This initial configuration must 
be maintained for possible use in error recov- 
ery and diagnostics. 

EU ERROR DETECTION METHODS 

Three error-detection systems are used in 
the EU, namely, parity checks, residue checks, 
and continuity checks. Parity is used to detect 
errors in EU local storage and in data received 
from other units. Mod 3 residue is used to de- 
tect errors anywhere in the EU data paths 
and data registers, but not in either the EU lo- 
cal storage or most control registers. Also, the 
residue logic checks addresses sent to the EU 
from the AU or SU. In addition, residue is the 
primary means for detecting errors caused by 
an extra data transfer signal. Continuity 
checking, the use of a validity bit which indi- 
cates if the current contents of a register are 
valid, is used to detect missing, and sometimes 
extra, data transfer signals for the most com- 
monly used EU data paths. 

The implementation of these methods pro- 
duced the following results: 

a. The EU continuity logic provides a consi- 
derable check on the sequence of operators 
and control bits sent to the EU by the PCU. 

b. The EU residue system detects errors in 
arithmetic operations, field and bit extractions 
and insertions, and barrel shift operations. 

c. The EU parity logic detects data storage 
and transfer errors involving the EWR, the 
EU local storage, the associative memory, and 
the stack buffer. 

d. Continuity and residue checks detect most 
errors involving the generation of subcom- 
mands and data transfer signals. 

STACK BUFFER 

The stack is an area of memory assigned to 
a job to provide storage for basic program and 
data references. The stack also provides tem- 
porary storage of data and job history. When 
a job is activated, a linkage between its stack 
and the top-of -stack operands (A and B) is es- 



tablished by the stack pointer register (S), 
which contains the memory address of the last 
word pushed into the top of the stack. The 
stack buffer serves to extend the stack 
memory area into processor local IC memory 
and to provide quick access for stack 
manipulation by the execution unit. (See fig- 
ure III-1-12.) 



STACK BUFFER FUNCTION 

The primary purpose of the stack buffer is 
to hold, locally, a portion of the stack environ- 
ment. New stack items are entered into the 
stack buffer from the EU in such a manner 
that the last item placed in the stack is the 
first to be extracted. After the two top-of- 
stack positions in the EU are filled, loading a 
third operand onto the top of the stack causes 
the first to be pushed into the stack buffer. As 
entries are pushed into the stack buffer, and 
saturation is attained, a segment of buffer en- 
tries is autonomously moved into main 
memory so that the stack buffer maintains the 
top area of the stack memory area. Any stack 
adjustment to main memory is always accom- 
plished in multi-word segments in order to 
take full advantage of the phased memory sys- 
tem. Thus, the stack buffer tends to capture 
the current addressing environment of the ex- 
ecuting program stack. 

In the B 7700 processing system the stack 
buffer can be directly addressed, within limits, 
as if it were actually an area of main memory. 
The direct addressing of the stack buffer is 
transparent to the programmer. Therefore, 
knowledge of this action is not necessary for 
the programmer. 

STACK BUFFER OPERATION 

As shown in figure III-1-13, the major 
elements of the Stack Unit include the stack 
buffer, stack link (KL) register, stack vulnera- 
bility (KV) register, limit, local, and vulnerabil- 
ity comparators, stack length (KLN) register, 
subtractor, and associated stack controls. 

The stack buffer is a 32-word local storage 
area consisting of four 8-word segments. Each 
storage word in the stack buffer consists of 54 
bits. These bits comprise 48 bits of informa- 
tion, three tag bits, a parity bit, and two mem- 
ory error bits. The memory-error bits are de- 
fined as follows: 

SB53 SB52 

1 No error. 

1 11 bit error during a fill operation. 

1 Error other than a 1 bit error during 

a fill operation. 
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The buffer may contain from to 32 words 
of the active stack. All valid contents of the 
buffer have contiguous main-memory ad- 
dresses. The main-memory addresses for the 
contents of the stack buffer are indicated by 
three 20-bit registers: the S register, the stack 
link register, and the stack vulnerability regis- 
ter. 

The stack register (S register) holds the ad- 
dress of the top item in the stack buffer. Also 
functions as the stack buffer read/write point- 
er for POP/PUSH operations. 

The stack link register (KL) contains the ad- 
dress for the bottom (or oldest) item in the 
stack buffer. In addition, the KL register pro- 
vides memory address information for Comm 
Unit functions as the stack buffer read point- 
er during empty operations, and as the stack 
buffer write pointer during fill operations. 

The third register, the stack vulnerability 
register (KV) along with four top of stack vul- 
nerability flip-flops (TKVO thru TKV3) are 
used to identify fetched buffer locations be- 
tween S and KV (S > MAR > KV). The purpose 
of this logic is to detect when the EU pops 
stack buffer contents that were previously 
fetched and placed in the EU data queue by 
the Storage Unit. This condition will occur 
during certain program applications. 

Any time the Storage Unit fetches an ad- 
dress between S and KV, the TKV flip-flop cor- 
responding to the relative address (0 thru 3) 
above the address in the KV register is set. If 
the EU executes a pop out of an address iden- 
tified by a set TKV, the stack buffer sends sig- 
nal KRSN.l to the EU. As a result, the EU 
notifies the PCU of change of direction, a clear 
queue is issued by the PCU, the Storage Unit 
fetch is again executed, and the instruction, 
which follows the instruction calling the fetch, 
is issued to the EU by the PCU. 

Initially KV is set to S-4 during the return 
or Set Processor Register "S" operation. In all 
following operations, any change of S contents 
results in a corresponding change of KV con- 
tents. Consequently, the contents of KV al- 
ways remain at S-4. 

Any set TKV flip-flop is cleared if four con- 
secutive pushes into the stack occur before a 
pop is executed. All set TKV flip-flops are re- 
set if a return/SPRR, store, or push condition 
occurs. 

In local return or local SPRR operation, the 
subtractor subtracts the contents of KLR from 
the least significant bits in the MAR, then 
adds to the difference the count of one. The 
result is placed in KLN to identify the new 
stack length. 



The memory copies present (MCP) flip-flop, 
when set, informs the Storage Unit to store to 
main memory even though a store or overwr- 
ite is found local in the stack buffer. MCP is 
set anytime a fill operation is required before 
executing an EU pop operation. MCP is reset 
when a word is pushed into the top of the 
stack buffer. 

The 5-least significant bits of the S register, 
MAR register, and KL register are decoded to 
select stack-buffer word locations, which range 
from thru 31. When storing to or fetching 
from the top of the stack buffer, the S register 
is selected as the pointer into the stack buffer. 
MAR register is selected as the pointer source 
for the Storage Unit, KL register is selected as 
the pointer source for the Comm related oper- 
ations; fill, empty and purge. 

FETCHING THE TOP ITEM FROM THE STACK 
BUFFER 

When the top item in the active stack is re- 
quired in the EU for use as the A or B oper- 
and (an action referred to as a "pop" of data 
from the stack), a main-memory fetch is not 
required unless the stack buffer is empty. 

If the stack buffer is not empty, the top item 
in the buffer is read from the buffer and 
transferred to the EU, and the contents of 
both the S register and the KV register are de- 
creased by 1. At the same time, the stack buf- 
fer checks to ensure that the address in S is 
not less than the address in F. If S is less than 
F, then stack underflow is detected. (F con- 
tains the address of the top MSCW in the ac- 
tive stack.) 

If the stack buffer is empty and a "pop" is 
required, first the address in KL is decreased 
by 4. The KL address is passed to COMM and 
used to fetch the top four words of the active 
stack from main memory. The contents of KL 
are used as a buffer address then counted up 
as each word is received. After the four words 
have been entered into the stack buffer, the 
contents of KL are decreased by four so that 
it again points to the bottom word in the buf- 
fer. (This action is called a "fill" operation.) 
With the required information now in the 
stack buffer, the "pop" described in the pre- 
ceding paragraph occurs. 



ADDING A NEW ITEM TO THE CONTENTS OF THE 
STACK BUFFER 

When the A or B operand in the EU must be 
placed in the active stack to establish the 
proper operand configuration for execution of 
the next operator, the operand is transferred 
into the stack buffer. Because this operand is 
added to the top of the active stack, the 
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operation is referred to as a "push" of data 
into the stack. A "push" of data from the EU 
into the buffer will not cause a store to main 
memory unless the stack buffer is full. 

If a "push" is required when the stack buf- 
fer is not full, the S register contents are in- 
creased by 1, then the operand to be added to 
the stack is transferred from the EU to the 
stack buffer and written into the stack-buffer 
location identified by the contents of the five 
least-significant bits of the S register. 

If the MCP flip-flop is set, the KLN register 
is preset to 1 so that the first push is effec- 
tively into an empty stack. Also, the contents 
of the S register (S + 1) are loaded into KL to 
indicate that only one location is valid in the 
stack buffer. 

If the stack buffer is full and a push is to be 
performed, four buffer words are stored to 
main memory, and then the data in the EU 
may be placed in the stack buffer. (This 
operation is referred to as an "empty" 
operation.) 

This is accomplished by requesting COMM to 
perform an overwrite of the four oldest words 
into memory. The KL address is passed to 
COMM and used as the start address for the 
overwrite. Because KL register functions as 
the read pointer for the stack buffer, COMM 
increases KL contents by 1 as each word is 
transferred to memory. At the same time, the 
contents of KLN are decreased by 1. After the 
"empty" operation, the push of new entries 
into the stack buffer from the EU may pro- 
ceed as described in the preceding paragraph. 

Each time a push is to be performed, the 
stack buffer compares the contents of the S 
register to the contents of the limit of stack 
register (LOSR). The LOSR contains the ad- 
dress of the highest usable location in the ac- 
tive program stack. If S equals LOSR, a stack 
overflow interrupt is generated. 

FETCHING AND STORING OF LOCAL INFORMATION 

The stack buffer maintains up to 32 words of 
the top items in the active stack. The storage 
unit can fetch from or store to any point in 
the buffer that is within the local addressing 
environment. Therefore fetch requests made 
by the EU for any of the items "captured" lo- 
cally in the stack buffer can be fulfilled with- 
out a main memory access. When updated in- 
formation is stored to an address which is lo- 
cal, the store operation is performed to the 
stack buffer. 

However, if the contents of MA are equal to 
KL, or the MCP is set, the information is also 
stored to memory because it may be the least 
significant half of a double precision word. 
The local addressing environment includes all 
items between S and KL. 



For local stores or overwrites, the selected 
SU data queue information is simply written 
into the stack buffer location pointed to by the 
least significant 5 bits of the MAR. 

For local fetches, the selected buffer infor- 
mation is simple transferred to the EWR reg- 
ister. At the same time, a comparator deter- 
mines if MAR is greater than KV and if S reg- 
ister is greater or equal to MAR. If both of 
these conditions are met, the operation is not 
a vector mode fetch, and the two least 
significant bits of MAR are set to some binary 
count of thru 3, one of four TKV flip-flops is 
set. This identifies that the fetch was obtained 
from one of the top four locations in the stack 
buffer. 
STACK BUFFER PURGE OPERATION 

A store to main memory is initiated when 
the stack buffer is purged. A purge causes all 
buffer words with main memory addresses be- 
tween S and KL to be stored to memory. After 
a purge operation, the stack buffer is marked 
empty. A stack-buffer purge occurs each time 
an SPRR63, SPRR52, RDLK, MVST or SLMT 
operator is executed. 

If RDLK or SLMT is preceded by FMFR, 
stack purging will not occur. 

ASSOCIATIVE MEMORY 

The associative memory (ASM) is a general 
data buffer, implemented to provide fast ac- 
cess to frequently used variables and descrip- 
tors which are outside the area contained in 
the stack buffer. 

The ASM is loaded with any item fetched 
from main memory except those items fetched 
during execution of the masked search for 
equal, linked list lookup, or fetch memory fail 
register or any operators preceded by a fetch 
main memory reference operator. As shown in 
figure III-1-14, the major elements of the ASM 
include the following: 

a. Data Array - Consists of 1024 words, each 
word of which contains 48 data bits, three tag 
bits, a data valid bit, and an error bit. The 
1024 words are divided into 64 blocks (0 thru 
63), each block of which contains four four- 
word groups. 

b. Address Array - Consists of 256 address 
words, each address word of which contains 12 
most significant bits of main memory address 
plus 2 bits of residue. The 256 address words 
are divided into 64 blocks (0 thru 63), each 
block of which contains four address words. 

c. Priority List Array - Consists of 64 (0 
thru 63) priority words, one word for each one 
of the 64 address array blocks. Each priority 
word contains three two-bit priority codes. 
These priority codes identify the oldest ad- 
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Figure 111-1-13. Stack Unit, Block Diagram 



dresses within an address array block as fol- 
lows: 



Priority Cod* 


Definition 


Bits 




5 and 4 


Third oldest (or second newest) address 




word. 


3 and 2 


Second oldest address word. 


1 and 


Oldest address word. 



NOTE 
The newest address is derived 
from decoding Priority List regis- 
ter output into a two-bit code (7 
and 6). 

d. Priority List Register - Displays the word 
in the Priority List Array selected by memory 
address currently available in the ASM. 

e. Address Residue Decoder - Subtracts the 
residue of bits and 1 from residue bits 20 and 
21 of the current memory address in the ASM. 
The resultant residue, along with the new ad- 
dress, is stored in the proper address array lo- 
cation and is also sent to the address compara- 
tor. 

f. Address Comparator - Compares the 12 
most significant bits of the current memory 
address and the associated residue with each 
one of the four address words (plus their 
residue) stored in the selected address array 
block. If any address word compares with cur- 
rent memory address, the comparator develops 
a two-bit code to identify that address word 
and a signal which informs the SU or CU that 
information was found locally in the ASM. 

g. Priority List Shifter - Shifts the three 
two-bit codes of the PL register right or left 
by multiples of two bits. The output of the 
shifter is then written back into the addressed 
word location of the priority list array. The 
conditions for shifting the three two-bit 
priority codes are as follows: 

1. When an address word in the address 
array block is designated as the newest 
address by a priority code, all codes to 
the left of the code identifying the new- 
est address are shifted right by two 
bits. 

For example: 

NEW Decode of PL PL 5,4 PL3,2 PL1.0 
0,1 Reg. PL7.6 

00 11 10 01 00 (orig. 

state) 

00 11 10 01 (next 

state) 



2. When an address word in the address 
array block is designated as the oldest 
address by a priority code, all codes to 
the right of the code identifying the old- 
est address are shifted left by two bits. 

For example: 

NEW Decode of PL PL5.4 PL3.2 PL1.0 
0,1 Reg. PL7.6 

11 01 11 10 00 (orig. 

state) 

01 10 00 11 (next 

state) 



h. Selection Logic - Selects two-bit code 
from address comparator when storage unit 
has control of ASM or when CU is performing 
stack empty operation or entering an error 
word into the ASM. Selects bits and 1 of pri- 
ority register when CU is performing a fill op- 
eration in the ASM. 

ASM LOCAL OPERATION 

On all local fetch, store, and overwrite 
operations, a check is made under control of 
the storage unit to determine if the requested 
information is currently contained in the asso- 
ciative memory. As shown in figure III-1-14, 
the contents of the MAR are presented to the 
data array, address array, and address compa- 
rator through the address selection and ad- 
dress decoder logic. The control circuitry of 
the ASM reads the four addresses in the ad- 
dress array block which is selected by address 
bits 2 thru 7, then the comparator circuit com- 
pares these addresses with address bits 8 thru 
19, and the 2 bit residue decode. 

If a compare exists within the four ad- 
dresses, the address groups is declared local 
and a two-bit code, identifying this group, is 
passed onto the data array logic. In effect, the 
two-bit code provides the enabling controls for 
reading from or writing into the corresponding 
four-word group in the data array. 

Other enabling controls are provided by the 
two least significant bits of address. These bits 
select the word location (0, 1, 2, or 3) within 
the four-word group. For local fetches, the 
data word is simply read out to the EWR in 
the execution unit. For local stores and over- 
writes, the data from the storage data queue 
is strobed into the proper word location of the 
ASM. Note that protected stores are detected 
on the store to ASM operations. In the event 
that a protected write is found in the ASM, 
the store to ASM operation is terminated. 

The decode of memory address bits 2 thru 7 
selects one of the 64 priority array locations. 
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Figure ill-1-14. Associative Memory 



The priority word in that location is then read 
out to the priority list register and passed onto 
the priority list shifter. Here, after the 
memory address is designated the newest ad- 
dress, the order of the three two-bit priority 
codes is updated to designate the three oldest 
addresses with the selected address array 
block. The new order of address codes is then 
written back into the addressed location of the 
array. 

ASM FILL OPERATION 

The ASM fill operation begins by decoding 
address bits 2 thru 7 from the CA register. As 
in the ASM local operations, the decode of 
these bits selects one of the 64 block locations 
in the data array, one of the 64 block locations 
in the address array, and one of the 64 priority 
list array locations. The priority word in that 
location is read out to the priority list register. 
Then on command from the CU, the oldest ad- 
dress location, as defined by bits and 1 in the 
priority list register, is invalidated by writing 
zeros into the associated address residue bit 



locations. As the new address is written in, the 
data word received by CU is subsequently 
written into the data array location referenced 
by the oldest address word and the two LSB's 
of address in the CA register. The two LSB's 
of address in the CA register are counted up 
so that next data word can be placed into 
proper ASM location. Upon completion of the 
fill operation, correct residue is generated and 
written into the associated residue bit loca- 
tions of the address word. 



ASM PURGE OPERATION 

The hardware can invalidate all information 
in the ASM and initialize all locations in the 
priority list array when necessary such as 
when entering the MCP for reallocation. To 
purge the ASM, 0's are written into all address 
residue bits. To initialize the priority list ar- 
ray, binary codes of 00, 10, and 01 are written 
into bit locations 0, 1; 2, 3; and 4, 5, respective- 
ly, of each word in the array. 
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STORAGE UNIT 

The storage unit (SU) controls the initiation 
of memory fetches other than program code 
fetches, stack fills and empties, and of all 
store operations. The actual operations with 
main memory are performed by the communi- 
cations unit, but the storage unit assembles 
the memory address and control information 
and for stores supplies the data to the commu- 

PCU (OP. CODES) 



nications unit. As part of its functions, the SU 
controls the checking of the stack buffer and 
associative memory local addresses to deter- 
mine if the required operation is to be per- 
formed locally. 

The storage unit is capable of performing 
overlapping operations. Such overlap occurs 
whenever a main-memory fetch is initiated. 
While the communications unit is fetching the 
requested information, the storage unit can go 
on to the next entry in its operations queue. If 
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that operation references an item that is local 
in the stack buffer or the associative memory, 
then the local reference is completed in paral- 
lel with the main memory reference. The over- 
lap is not restricted to one operation. The stor- 
age unit is free to process operations from its 
queue until another main-memory reference is 
required. 

The block diagram of the storage unit, fig- 
ure III-1-15, shows the general flow of infor- 
mation through the unit. In preprocessing the 
operators in the program code string, the PCU 
determines if a fetch or write-type operation is 
required for the execution of the operator. 

Only fetch-type operations, such as Value 
Calls or Name Calls concatenated with an in- 
dex-type or enter operator, are initiated by the 
PCU. If such an operation is required, the 
PCU operation codes are passed directly to the 
SU variant flip-flops and length register. At 
the same time, the memory address for this 
operation is calculated by the AU and passed 
directly to the MA register. For write-type op- 
erations (stores, overwrites, and certain 
string-type operations which execute write op- 
erations) the PCU enters a wait bit into the 
operations queue. 

If the store or overwrite is concatenated 
with a Name Call, the memory address is 
loaded in SIR and then queued with the wait 
bit. If the address information is not available, 
the wait bit is queued without an address, and 
the address is supplied during execution by 
the EU. If the operation queue is empty when 
a PCU job is available and the EU is not re- 
questing the SU, in addition to being written 
into the queue, the job is passed directly to the 
variants flip-flops and length register, and the 
address, if available, is passed to the MA reg- 
ister. The storage unit data queue is used to 
hold the information for store-type operations. 
The information to be stored is always sup- 
plied by the EU. 

INPUT TO STORAGE UNIT OPERATIONS 
QUEUE 

The 6-bit input operation register and stor- 
age input register (SI) serve as the write regis- 
ters for the storage unit operations queue. The 
PCU loads the 6-bit input operation register, 
then initiates the write cycle. The types of in- 
formation which can be loaded into this regis- 
ter include the following: 

1. 1WT - Wait bit is set whenever a store or 
overwrite operation is to be performed. 

2. 1MR - Memory reference bit is set when- 
ever a fetch is preceded by a FMMR (force 
main memory reference) operation. 



3. 1QL0 & 1QL1 - Two bits which identify 
the EU-data queue address for fetch 
operations. 

4. 1LD - Look for double precision bit is set 
whenever a single word fetch or certain vector 
mode single word fetches are performed. 

5. 1L2 - Length two bit is set whenever a 
fetch of the MSCW and RCW is required as 
the result of the PCU preprocessing a return 
or exit operator. This bit is also set when a 
two word vector mode fetch is required. 

The contents of the SI register include a 20- 
bit memory address field and two bits of 
residue on the address. The memory address 
and residue are loaded by the AU when avail- 
able. 

STORAGE UNIT OPERATIONS QUEUE 

The storage unit operations queue is a local 
storage area containing eight locations. The 
operations in the SI register are written into 
successive locations in the queue, and subse- 
quently read from the queue and processed by 
the SU in the order in which they were 
queued. The queue address for writing into 
the queue is provided by the storage 
operations write pointer (SQW). The pointer is 
counted up after each write operation. A read 
pointer (SQR) provides the location in the 
queue of the next word to be read from the 
queue. 

LOADING THE STORAGE UNIT OP CODE 
FLIP-FLOPS 

The OP code flip-flops are the primary con- 
trol flip-flops for EU-initiated jobs. The con- 
tents of these flip-flops identify the SU 
operation currently requested by the EU. The 
operations are defined as follows: 
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*This operation is performed as an overwrite-type 
operation by the SU. 

LOADING THE STORAGE UNIT VARIANTS 
FLIP-FLOPS 

There are seven variants flip-flops which 
contain additional control information for the 
operation currently being performed by the 
SU. These flip-flops are loaded from either the 
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queue, input operation flip-flops, PCU, or the 
EU. The type of information loaded into the 
variants flip-flops includes the following: 

1. SBY - Bypass operations queue. SBY flip- 
flop is set by all EU-initiated jobs, except 
those cases involving certain store and 
overwrite operations. This flip-flop is only set 
by stores arising from tracing through a chain 
of IRW's or linked descriptors. This flip-flop is 
not set when an overwrite is issued to the SU 
as a result of the EU processing the step and 
branch operator. 

2. SEW - Request use of the EWR in the 
EU. SEW flip-flop is set by all EU-initiated 
jobs, except overwrite operations not within a 
string operator. 

3. SQLO and SQL1 - Two bits which identify 
the EU-data queue address for PCU fetch op- 
erations. 

4. S4A - 4 word ASM. S4A flip-flop is set by 
all operations, except Masked Search For 
Equal, Linked List Lookup, fetch of MSCW, 
RCW for Exit and Return, and operators pre- 
ceded by FMMR. 

5. SMR - Memory reference. SMR flip-flop is 
set whenever the SU receives a PCU or EU-in- 
itiated job as the result of executing a pro- 
gram operator preceded by FMMR. 

6. SLD - Look for double precision. SLD flip- 
flop is set whenever EU-initiated IRW fetches 
(excluding those issued by the enter or 
evaluate operator) and load transparent fetch- 
es are performed. This flip-flop is also set 
whenever PCU-initiated single word fetches 
and certain vector mode single word fetches 
are performed. 

LOADING THE STORAGE UNIT LENGTH 
REGISTER 

The length register is a 3-bit register which 
contains the number of words to be stored or 
fetched for PCU or EU-initiated operations. 
All operations have a length of 1 or 2, except 
certain jobs issued by string and edit 
operators. String and edit fetches can have a 
length of 4, string stores have a length of 4, 
and string overwrites have a length of 4, ex- 
cept for the last overwrite which can have any 
length (up to 4 words). 

STORAGE UNIT DATA QUEUE 

The storage unit data queue contains four 
52-bit word locations. A separate write pointer 
(SDW) and read pointer (SDR) are used for ad- 
dressing in the SU data queue. Writing into 
the queue is performed only by the EU. Infor- 
mation is read from the queue under control 
of the SU. The information taken from the 
queue is usually passed to the communications 
unit for storage in main memory, but is also 
sent to the associative memory and stack buf- 



fer when the store is to an address which is lo- 
cal. 

Because the EU must determine that the 
store was completed successfully before addi- 
tional operators can be executed, the SU data 
queue contains the data for only one store op- 
eration at a time. The queue is four words 
long so that it may hold the data for any mul- 
ti-word store operation. 

MEMORY ADDRESS REGISTER 

The MA register, which contains the 
memory address for the current operation, is 
loaded from the queue, from the EU, from the 
AU, or directly from the SI register. The ad- 
dress in the MA register is sent to the stack 
buffer and associative memory to allow these 
units to determine if the address is local, and 
is forwarded to the communications unit for 
use in main memory operations. 

For multi-word operations, the starting ad- 
dress is forwarded to the CU, then the address 
in the MAR is counted up so that a check for 
local addresses may be performed on each ad- 
dress involved in the multi-word operation. 



STORAGE UNIT CONTROL LOGIC 

The timing and controls for SU operations 
are provided by this portion of the SU. The op- 
erations include special fetches, read with lock 
functions, single or multi-word fetches, pro- 
tected stores, or overwrites. At the start of 
any operation, the control logic obtains access 
to the ASM, and, if necessary the SB and the 
EWR. Then the CU is started if an EU-ini- 
tialed fetch is to be performed, and a check is 
made to determine if the address is local in 
the SB or ASM. The CU is not required during 
overwrite and stores if the address is local in 
the SB, the stack does not contain memory 
copies, and the MA is not equal to KL (oldest 
entry in stack buffer). If MA equals KL, the 
information in location referenced by KL is 
stored to main memory because it may be the 
least-significant half of a double precision 
word. If, during a local store operation, a pro- 
tected write is discovered in that location, the 
CU and SU operations are terminated. Also, 
the CU operation is terminated if a protected 
write is found in main memory. 

For single-word fetch operations, if the in- 
formation is locally available in the SB or 
ASM, the information is transferred to the 
EWR in the EU and the CU operation is termi- 
nated. However, the CU performs a residue 
check on the address even though the address 
is local. If both SB and ASM contain the infor- 
mation, only SB information is transferred to 
the EWR. A check is performed to determine 
if information in EWR is a double precision op- 
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erand (tag 2) or is a nonpresent descriptor (bit 
47 set). If a tag 2 is found, a local check of 
next address is performed for second half of 
the double precision operand. If non-present 
descriptor is found, the memory address from 
which the descriptor was fetched is sent to the 
EU-data queue. 

For multi-word fetch operations, if all of the 
information is available only in the stack buf- 
fer (above KL) or ASM, the CU operation is 
terminated. If some of the information is 
available only in the stack buffer or ASM, the 
portion in main memory is fetched, then the 
portion in the stack buffer or ASM, if not cop- 
ied in stack buffer, is fetched. 

For store and overwrite operations queued 
by the PCU, a wait bit is set in the operation 
code. When the operation is performed, this 
wait bit causes the control logic to hold the op- 
eration until the required data has been en- 
tered into the SU data queue. If the address is 
not provided from the queue, the SU also 
waits until the MA is loaded by the EU or the 
AU. When the information is available, the 
control logic enables the read lines of the SU 
data queue and disables the write lines of the 
queue until the operation is complete. For sin- 
gle word and multi-word store operations, if 
address is local, the SU changes the store to 
an overwrite operation and sends the informa- 
tion found in local storage to the EWR. There 
a check is made to determine if information 
being replaced in local storage has protect bit 
on (bit 48) before the local store is completed. 
If the protect bit is on, the write into local 
storage is not performed, and the CU 
operation is terminated. If a store is preceded 
by a FMMR instruction, the local storage 
words are not examined for protect bit be- 
cause the words in the equivalent memory ad- 
dresses are more current than those in local 
storage. Thus, it becomes necessary to use 
memory flashback to determine if any of the 
memory words are protected. If the memory 
addresses do not contain protected words, the 
SU changes the store to an overwrite 
operation and then proceeds to complete the 
local storage operation. If a protected word is 
sensed, the memory returns the failsoft com- 
mand, which, in turn terminates the local 
store and CU operations. 



On completion of any store or overwrite op- 
eration, the control logic resets the SU data 
queue pointers to zero and enables the write 
lines when CU has completed its portion of the 
operation. 



COMMUNICATIONS UNIT 

The communications unit (CU) provides the 
interface between the CPM and main memory. 
All main memory accesses are performed by 
this unit. Requests for memory operations are 
made to the CU by the program buffer, the 
storage unit, and the stack buffer. Informa- 
tion fetched by the CU from memory is for- 
warded to the execution unit, the stack buffer, 
the associative memory, or, for program code, 
to the program buffer. 

Access to the CU is granted to the request- 
ing CPM units on a priority basis. First 
priority is given to the stack buffer, because 
the EU is waiting for the results of any re- 
quest made by the stack buffer. The stack buf- 
fer requests are made when performing a 
stack-buffer fill, empty, or purge operation. 
The storage unit has second priority as the 
EU may be waiting for the results of an SU 
request. The program buffer requests have 
third priority as these requests are made in 
anticipation of the actual need for additional 
program code. 

The major logic elements of the CU, as 
shown in figure III-1-16, include input (IN) 
and output (OP) registers, the communications 
address (CA) register, the communications 
length (CLN) register, the cancel length regis- 
ter, the start address flip-flops the remember- 
suspend (RS) register, the fail (FR) register, 
and the control logic. 

For all memory operations, the absolute 
memory address is contained in the CA regis- 
ter and the number of words to be fetched or 
stored is in the CLN register. During the oper- 
ation, both the address and the word count are 
adjusted for each word fetched or stored. In 
addition to holding the absolute memory ad- 
dress and word count of an operation, the CU 
is also supplied with a start address and can- 
cel length count whenever the CU is servicing 
a storage unit fetch operation. This combined 
information informs the CU on what portion 
of a multi-word fetch from memory is sent to 
the EU. This condition arises as the result of 
the storage unit locating one or more words in 
local storage and the remaining words in main 
memory. Thus only those non-local words re- 
maining in memory are sent to the EU even 
though the entire fetch from memory is loaded 
into the ASM. The other portion of the fetch 
was previously supplied to the EU during the 
local fetch operation. In most cases, the stor- 
age unit fetch is accompanied by an ASM load 
operation and thus a four-word fetch is re- 
quired from memory. 
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Program code is fetched in eight-word 
blocks, which requires two four-word fetches. 
If, at the end of the first four-word fetch of 
program code, assuming an MSU configura- 
tion, a higher priority request has been made 
for CU use, the current memory address and 
word length are transferred to the remember- 
suspend register for temporary storage. Then 
the second four-word fetch is delayed until af- 
ter the higher-priority request has been serv- 
iced. When no other requests are pending, the 
RS register contents are loaded back into the 
CA and CLN registers and the fetching of code 
is resumed. 

When access to main memory is required, 
the CU control logic compares the six most-sig- 
nificant bits of the address in the CA register 
with the limits established for each MCM, and 
selects the appropriate module. Then, the 
starting address and other control information 
for the operation are sent to the selected mod- 
ule in a memory control word. The control 
word is assembled in the input register, then 
transferred to the output register and is sent 
to the addressed memory control module. The 
receipt of the control word is acknowledged by 
the MCM. 

For fetch operations, the MCM notifies the 
CU that access has been granted by sending 
an ACK signal. A Data Present (DAP) signal 
along with the data is then sent to the CU. 
The data is received by the IN register and is 
subsequently forwarded to the program buf- 
fer, the stack buffer, the associative memory, 
or the EWR, as appropriate. 

If a memory related error is detected by the 
CU during a fetch or flashback operation, the 
word, which is involved at the time of the fail- 
ure is replaced by an error word. This error 
word, which is a copy of the control word, is 
contained in the OP register, then transferred 
with other related information into IN, and IN 
sends the error word to the location that is to 
receive the expected memory word. (See figure 
III-1-17 for format of the error word.) 



Data for store operations is received by the 
CU from either the SU data queue or the 
stack buffer. Data for store operations is buf- 
fered in the IN register until the CU gains 
memory access. Following the transfer of the 
control word and the acknowledgement of the 
receipt of this word, the selected MCM will in- 
form the CU of access by sending a send-data 
signal to the CU. On obtaining access, the CU 
transfers the data into the output register and 
the word is then sent to the selected MCM. 

The fail register (FR) is used to provide in- 
formation concerning processor internal and 
memory related error conditions. When an er- 
ror condition is detected, a bit assigned to des- 
ignate that condition is set in the FR register. 
Detailed discussion of the FR register is pro- 
vided in Section 2 Interrupts of this manual. 

FAULT CONTROL LOGIC 

The fault control logic is mechanized in such 
a way as to aid in general maintenance and er- 
ror recovery under the guidance of the MCP. 
Error recovery is aided by a system of multi- 
ple levels of control mode coupled with al- 
ternate stack and display zero capabilities. 
The fault condition register records system in- 
terrupts and conditions the processor to take 
the necessary action in order to handle these 
interrupts (see figure III-1-18). This register 
records both operator dependent and operator 
independent interrupts. The program index 
and program syllable counts on operator de- 
pendent interrupts are adjusted to allow re-ex- 
ecution of the interrupted operator. The 
operator independent interrupts are processed 
at the conclusion of the operator being 
executed at the time of the interrupt. 

The interrupt system allows for special 
"complete" communication and for recording 
single-bit errors and two-bit errors from main 
memory. It also allows for the sensing and re- 
cording of special errors internal to the main 
memory and Central Processor. 
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OPERATION 

43 42 41 

SINGLE DATA WORD FETCH 

N-LENGTH DATA WORD FETCH 

FAIL REGISTER FETCH 

1 SINGLE-WORD OVERWRITE WITH FLASHBACK 

SINGLE-WORD PROTECTED WRITE 

1 SINGLE-WORD PROTECTED WRITE WITH FLASHBACK 
N-LENGTH OVERWRITE 

SINGLE-WORD OVERWRITE 

N-WORD PROTECTED WRITE 

1 LOAD REQUESTOR INHIBITS 

1 LOAD MEMORY LIMITS 



NO-ACCESS-TO MEMORY OR INVALID CHANNEL 



WRONG PARITY ON 

INCOMING MEMORY TRANSFERS 



FAIL 1 INTERRUPT 



COMM INTERNAL (RESIDUE 
ERROR IN CA) 



Figure 1 1 1-1 -17. Error Word Format 
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INTERRUPTS 



INTRODUCTION 

An interrupt is a means of diverting a proc- 
essor temporarily from the job which it is 
doing if certain predetermined conditions oc- 
cur, so that some higher priority job may be 
done immediately. Interrupts are processed by 
the interrupt handling mechanism of the MCP. 
When the interrupt has been processed, the 
MCP will (if conditions permit) reactivate the 
interrupted process. 

The interrupt handling mechanism of the 
MCP deals with two classes of interrupts: 
hardware interrupts and software interrupts. 
Hardware interrupts are generated 
automatically by the B 7700 system (when in- 
terrupt conditions occur) and are processed by 
the MCP interrupt procedure. Software inter- 
rupts are programmatically defined, and are 
used both by the MCP and by object programs 
for communication between processes. This 
discussion deals only with hardware inter- 
rupts. 

HARDWARE INTERRUPT SYSTEM 

The B 7700 hardware interrupt system is a 
primary interface between the MCP and the 
hardware. Interrupt conditions may be detect- 
ed by the Central Processor Module (CPM), the 
Input/Output Module (IOM); or the Memory 
Control Module (MCM). When detected, inter- 
rupt conditions are processed by the Fault 
Control Logic of the CPM. Normally, the CPM 
prepares the stack for procedure entry, places 
the necessary parameters in the stack, and 
causes an entry into the MCP interrupt proce- 
dure. 

CPM STATES AND MODES 

The CPM operates in either of two states: 
control state, used only by the MCP; or normal 
state, used both by user programs and by the 
MCP. Normal state is always used when 
executing user programs. Control state is used 
when executing certain portions of the MCP, 
including the MCP interrupt handling proce- 
dure. In the control state, external interrupts 
and interval timer interrupts are inhibited (ex- 
cept during an IDLE or PAUS instruction) 
and the CPM may execute privileged instruc- 
tions which it may not execute in normal 
state. 



In addition to the two states, the CPM can 
be in any one of five interrupt handling 
modes: Normal Mode (Control Mode 0), Control 
Mode 1 (CM1), Control Mode 2 (CM2), Control 
Mode 3 (CM3), and Control Mode 4. The CPM 
operates in normal mode until an interrupt 
condition is detected. The first three control 
modes allow for recursive attempts to enter 
MCP interrupt handling procedures by the 
fault control logic of the CPM. The CPM halts 
in Control Mode 4 if these attempts are not 
successful. The CPM will return to Normal 
Mode if an interrupt condition is handled suc- 
cessfully in CM1, CM2, or CM3. 

There is no direct connection between the 
states of operation and the modes of operation 
of the CPM. The CPM may be in control state 
or in normal state while in any control mode. 
In a system which contains more than one 
CPM, any or all of the CPM s may operate in 
control state or normal state, as well as in any 
of the interrupt modes. The CPM states are 
described below; the interrupt modes are fur- 
ther described in the discussion of interrupt 
processing. 

CONTROL STATE 

Entry into control state (from normal state) 
occurs when the MCP enters or returns to a 
control state procedure (an MCP SAVE proce- 
dure), or when the CPM executes a Disable 
External Interrupts operator (DEXI). (Control 
state procedures have bit 19, the N bit, of the 
PCW set.) While the CPM is operating in con- 
trol state the reporting of external interrupts 
to the MCP interrupt handling routine is dis- 
abled. Additionally, the CPM may execute cer- 
tain privileged operators while in control state 
which may not be executed in normal state. 
When the CPM is operating in control state, 
the normal control state flip-flop (PST) and 
the inhibit interrupt flip-flop (IIH) are both 
set (except during an IDLE instruction). 

The interrupts which are inhibited while in 
control state include the Channel interrupts, 
the IOM Error interrupts, the Interval Timer 
interrupt, and the Memory Fail 2 interrupts. 
Although the processing of these interrupts is 
inhibited,, the appropriate bit in the CPM In- 
terrupt (Fault) register will be set if one of 
these interrupts is detected, and the interrupt 
will be processed when the CPM enables Ex- 
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ternal interrupts either by returning to nor- 
mal state or by executing an IDLE or PAUS 
operator. 

The Egg Timer interrupt, although an exter- 
nal interrupt in priority, is not inhibited in 
control state. 

The operators which are enabled only when 
the CPM is in control state include Set Inter- 
val Timer (SINT), Inhibit Parity (IGPR), Set 
Memory Inhibits (SINH), and Set Memory 
Limits (SMLT). 

NORMAL STATE 

Return to normal state (from control state) 
occurs whenever the MCP initiates or returns 
to a normal state procedure (non-SAVE proce- 
dure), or when the CPM executes an Enable 
External Interrupt operator (EEXI). (normal 
state procedures have bit 19, the N bit, of the 
PCW reset). When the CPM is operating in 
normal state, the processor state flip-flop 
(PST) and the inhibit interrupt flip-flop (IIH) 
are both reset. When a CPM returns to normal 
state after servicing an interrupt, it does not 
necessarily return to the program which was 
executing when the interrupt was detected. 
The selection of the job to be run is a function 
of the MCP. 

FAULT CONTROL LOGIC 

The fault control logic of the CPM contains 
four registers which are used to record and 
process hardware interrupts: the Fault Condi- 



tion, Fault Mask, Fail, and Control Mode regis- 
ters. The Fault Condition register is used to 
indicate the detection of one or more interrupt 
conditions (one bit for each condition). The 
Fault Mask register is used to inhibit (mask 
out) the processing of one or more interrupt 
conditions. (The Fault Condition register may 
be read in such a way as to obtain only inter- 
rupt conditions which are not masked out; 
thus indicating an interrupt condition which 
must be processed by the MCP.) The Fail reg- 
ister further identifies errors which are inter- 
nal to the CPM and CPM-MCM interface er- 
rors. The Control Mode register is used to 
identify the interrupt mode (Normal, Control 
Mode 1, Control Mode 2, and Control Mode 3) 
in which the CPM is operating. 

In addition to the CPM registers, a Memory 
Fail Register in each Memory Control Module 
(MCM) is used to give detailed information 
about memory-related failures concerning that 
MCM. (Discussion of the MCM fail register is 
given in Chapter V of this manual.) For IOM 
error interrupts, detailed information about 
the IOM failure is given in an IOM Fail Word. 

FAULT CONDITION REGISTER 

The Fault Condition register contains one 
bit for each of the possible interrupt condi- 
tions (see table 1 1 1-2-1). The low order bits of 
the register are associated with interrupts 
which have the highest priority for being proc- 
essed by the CPM; the high order bits are as- 



Table 111-2-1. B 7700 Interrupt Bit Assignments 



Interrupt 


Fault 


Fault Mask 


Interrupt Went. (P1) 




Condition 


Register 


(Bit) 




Register 


(Bit) 






(Bit) 






Alarm (First Priority) 








Loop 





N 





Memory Parity 


1 





1 


Memory Fail 1 


2 


N 


2 


Invalid Address (No Access) 


3 


E 


3 Plus Bit 25 


Stack Underflow 


4 




4 


Invalid Program Word 


5 




5 


Processor Internal 


6 




6 


Syllable (Second Priority) 








Memory Protect 


9 







Invalid Operand 


10 




1 


Divide By Zero 


11 




2 


Exponent Overflow 


12 


N 


3 


Exponent Underflow 


13 





4 Plus Bit 24 or 






N 


Bit 23 (See Note) 






E 


1.) 


Invalid Index 


14 




5 


Integer Overflow 


15 




6 


Bottom Of Stack 


16 




7 


Presence Bit 


17 




8 


Sequence Error 


18 




9 


Segmented Array 


19 




10 


Programmed Operator 


20 




None 


Privileged Instruction 


21 




11 



3-42 



Table 111-2-1. B 7700 Interrupt Bit Assignments (Cont) 



Interrupt 



Special 

Stack Overflow (Third Priority) 

Interval Timer (Fifth Priority) 

External (Fourth Priority) 
Channel 
Channel 1 
Channel 2 
Channel 3 
Channel 4 
Channel 5 
Channel 6 
Channel 7 
IOM Error 
IOM Error 1 
IOM Error 2 
IOM Error 3 
IOM Error 4 
IOM Error 5 
IOM Error 6 
IOM Error 7 
Memory Fail 2 
Egg Timer 



Fault 


Fault Mask 


Interrupt Ident. (PI) 


Condition 

Register 

(Bit) 


Register 
(Bit) 




(Bit) 


24 


24 


1 




23 


23 





Plus Bit 22 


26 


26 







27 


27 


1 




28 


28 


2 




29 


29 


3 




30 


30 


4 




31 


31 


5 




32 


32 


6 




33 


33 


7 


Plus Bit 21 


34 


34 


8 




35 


35 


9 




36 


36 


10 




37 


37 


11 




38 


38 


12 




39 


39 


13 




40 


40 


14 




41 


41 


15 




42 


42 


16 




None 


None 


None 



NOTE 1: 

On syllable interrupts ID Bit 24 indicates class 1 interrupt (PIR, PSR, PDR, PBR have 
not been modified, ID Bit 23 indicates class 2 (PIR, PSR, PDR, and PBR are undefined). 



sociated with interrupts which have the lowest 
priority. When interrupt conditions are detect- 
ed, the bits associated with those conditions 
are set in the Fault Condition register. 

Normally, the Fault Condition register is set 
by the interrupt condition. As each interrupt 
condition is processed, the bits in the register 
are selectively reset. Programmatic control of 
the Fault Condition register is accomplished 
by use of the Set Processor Register (SPRR) 
and Read Processor Register (RRRR) 
operators. The RPRR operator causes the con- 
tents of the register to be placed in the stack, 
and the register itself to be reset. The SPRR 
operator causes an inclusive OR setting of the 
register; that is, bits are set, but bits which al- 
ready are set are not reset. 

FAULT MASK REGISTER 

The Fault Mask register allows the process- 
ing of certain interrupts to be inhibited or de- 
ferred. Alarm interrupts, Syllable interrupts, 
and the Egg Timer interrupt may not be 
masked. The Special interrupts and the other 
External interrupts ha.ve a corresponding bit 
in the Fault Condition and Fault Mask regis- 
ters (see table III-2-1). An interrupt condition 
will only be recognized by the CPM if the 
Fault Mask register bit for that condition is 
set (logical one). If the Fault Mask bit is reset 
for an interrupt condition, that interrupt bit 
will still be recorded in the Fault Condition 



register but will go unnoticed by the fault con- 
trol logic. If the mask configuration is later 
changed, then interrupts (including those 
resident in the Fault Condition register when 
the mask is changed) which are now unmasked 
will be recognized and processed. In this way, 
processing of selected interrupts can be de- 
ferred. 

The Fault Mask register may only be set 
programmatically. The Read Processor Regis- 
ter operator causes a simple read of the regis- 
ter (without reset); the Set Processor Register 
operator causes a simple set of the register 
(each bit is set either to logical one or to 
logical zero). 

INTERRUPT IDENTIFICATION 

Each interrupt condition reported to the 
MCP is identified by a unique literal value, 
known as interrupt parameter Pi (see table 
III-2-1). this parameter is passed to the MCP 
interrupt procedure by the fault control logic 
to identify the condition which is to be proc- 
essed. The PI parameter is derived from the 
contents of the Fault Condition and Fault 
Mask registers through a series of gates. In- 
terrupt conditions reported in the Fault Condi- 
tion register which are not masked out by the 
Fault Mask register are used to make up the 
PI parameter. 

Normally, this parameter is read and placed 
into the stack by the fault control logic, al- 
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though it may be read into the stack program- 
matically. In either case, the resultant action 
is as follows. The value of Pi is read into the 
stack and the bits which were set in PI are re- 
set in the Fault Condition register. In a partic- 
ular PI parameter, all interrupts of a 
particular priority level which are not masked 
out are reported, but only one priority level is 
reported on each read. The priority level re- 
ported will be the highest priority level for 
which there is at least one bit set in the Fault 
Condition register which is not masked out. If 
the value of the PI parameter is read pro- 
grammatically (using the Read Processor Reg- 
ister operator), and if there are no unmasked 
interrupts to report, a word of all zeros is read 
into the stack. (The fault control logic will 
read Pi only when there is an unmasked inter- 
rupt to report). 

CPM FAIL REGISTER 

The CPM fail register (see figure III-2-1) 
provides specific information about processor 
internal interrupts. The type of processor in- 
ternal interrupts is identified by one of seven 
bits in the CPM fail register. These bits are 
EU Continuity Error (EUC), EU Residue Er- 
ror (EUR), EU Parity Error (EUP), PCU Error 
(PER), Adder Residue Error (ADD), Input 
Register Parity (INP) and CU Residue Error 
(CRS). Usually only one of these bits is set for 
a given internal error. However, it is conceiv- 
able to have a CRS error occur during a mem- 
ory fetch operation and then to have it re- 



placed in the CPM fail register by another fail- 
ure in a subsequent processor operation. It 
can be determined that a CRS error occurred 
during a fetch and was the cause of the proc- 
essor interrupt by observing that P2 interrupt 
parameter contains a CU error word in which 
bit 37 is on. (Refer to figure III-1-17 for error 
word format.) 

The CPM fail register contains several bits 
which are useful in analyzing CU detected er- 
rors. Whenever the CU detects an error, the 
CU loads the Memory Control Module number, 
the most significant 6 bits of memory address, 
and the most basic type of operation informa- 
tion into the CPM fail register. The no-access- 
to-memory errors are detected by the CU, and 
include Wrong Channel Number (WCN) and 
Memory Time Out (MTO). The Single-bit error 
bit (F2) is set if one bit core error occurs dur- 
ing any memory operation. When the CPM fail 
register is read by using the Read Processor 
Register operator, the CPM fail register is 
cleared. 

When an alarm interrupt occurs during a 
store or overwrite type operation in the Com- 
munications Unit, the CPM interrupts immedi- 
ately. Thus, the information in the CU and 
memory portions of the CPM fail register is al- 
ways current provided OP=l. However, the CU 
may detect more than one error on fetch oper- 
ations before the CPM fail register is read be- 
cause the CU errors do not necessarily result 
in interrupts until an attempt is made to proc- 
ess the memory word involved at the time of 
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MADS 

OP 
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F2 

MTO 
CSE 
CRS 
INP 

WCN 

ADD 
PER 



Bit 



Error 



EUP 

\ EUR 

EXECUTION < EUC 

UN1T MES 



3:4 Box Number (MCM No.) 

9:6 Memory Address (most significant 6 bits) 

10 Operation (l = Store/0=Fetch) 

11 l=Stack Operation/0=Not Stack Oper. 

12 1=SU Oper./0=Not SU Oper. 

13 Single-Bit Error 

14 Memory Time Out 

15 Coram Single Error 

16 CU Residue Error 

17 Input Register Parity on data from CPM 

18 Wrong Channel No 

19 Adder Residue Error 

21 PCU Error 

22 EU Parity Error 

23 EU Residue Error 

24 EU Continuity Error 

25 Probable Inconsistent State 

26 Interrupt probably not caused by operator indicated by RCW 



Figure 111-2-1. CPM Fail Register 
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failure. In some cases, the memory word is 
never used because a conditional branch is 
taken or because it is an unused portion of a 
two- or four-word fetch. 

When information regarding a CU-detected 
error is loaded with an empty CPM fail regis- 
ter, the Communications Single Error (CSE) 
bit is set. If a subsequent CU error occurs be- 
fore the fail register is cleared, the CU will 
overwrite the previous information in the fail 
register and reset CSE. Thus, CSE reset in the 
fail register indicates that the CU and 
memory information may not correspond to 

The INR and MES bits in the CPM fail reg- 
ister indicate whether all information neces- 
sary to retry an operation has been preserved 
by the EU when an alarm interrupt occurs. If 
an alarm interrupt occurs, such as Processor 
Internal, and the MCP finds both INR and 
MES bits reset, instruction retry will be at- 
tempted. 

CONTROL MODE REGISTER 

The Control Mode register indicates the in- 
terrupt mode in which the CPM is operating. 
The use of interrupt modes provides for recur- 
sive entries into the fault control logic. The 
progression to higher interrupt modes is con- 
trolled automatically by the hardware. In ad- 
dition, programmatic control of the Control 
Mode register may be accomplished by use of 
the Read Processor Register and Set Processor 
Register operators. 

The Control Mode register contains three 
bits which display the interrupt modes of the 
CPM: the CM1 bit, the CM2 bit, and the CM 3 
bit. In Normal Mode, none of these bits are 
set. In Control Mode 1, only the CMl bit is set. 
In Control Mode 2, only the CM2 bit is set. In 
Control Mode 3, the CMl and CM2 bits are 
both set. In Control Mode 4, only the CM3 bit 
is set. The CPM will be halted with the last in- 
terrupt displayed in the Fault Condition regis- 
ter and the HSI flip-flop set if an interrupt is 
detected in CM3. 

The CPM operates in Normal Mode while not 
attempting to process an interrupt. When an 
interrupt condition is detected, the CPM ad- 
vances to CMl and attempts to call the proce- 
dure pointed to by D [ ] +3 (the MCP inter- 
rupt procedure) from the stack of the user pro- 
gram. If an interrupt is detected while in CMl, 
the CPM advances to CM2, changes the stack 



environment by moving to an alternate stack 
(determined by indexing the stack vector by 
the CPM number), and attempts to call the 
MCP interrupt procedure again. If an inter- 
rupt condition is detected in CM2, the CPM ad- 
vances to CM3, changes the entire environ- 
ment by setting D [0] to the value in the ADZ 
register, moves to the proper alternate stack 
in the new environment, and attempts to enter 
the interrupt handler at the new D [ ] +3. 

If still another interrupt is detected 
while in CM3, it is obvious that a recursive in- 
terrupt processing situation exists, and the 
CPM advances to CM4 and halts. If the CPM 
succeeds in entering the MCP interrupt proce- 
dure, the Control Mode register is reset to 
Normal Mode programmatically. 

IOM FAIL WORD 

The IOM Fail word (figure III-2-2) is a 48-bit 
word which contains information regarding er- 
rors which cannot be associated with a partic- 
ular channel or device. (Such errors cause an 
IOM Error interrupt). When an IOM Error in- 
terrupt occurs, an IOM Fail Word is built by 
the fail mode logic within the IOM translator 
and placed in the result descriptor word of the 
"Fail IOCB". The Fail IOCB is associated with 
Unit Designate Number 0. The Fail IOCB is 
delinked from the queue of Fail IOCB's and 
linked into the queue of completed IOCB's (de- 
fined by the Status Queue Header) in the 
same manner as a normal I/O termination. 

INTERRUPT PROCESSING 

All interrupt conditions which are reported 
in the Fault Condition Register and which are 
not masked out by the Fault Mask register are 
accumulated into a general signal to alert the 
fault control logic of the CPM to the fact that 
one or more interrupts require processing. 
When an interrupt requires processing the 
CPM will advance the Control Mode register 
(in most cases from Normal Mode to CMl) and 
will attempt to enter the MCP interrupt proce- 
dure. 

INTERRUPT PROCESSING IN NORMAL MODE 

After advancing the Control Mode register 
from Normal Mode to CMl, the CPM will at- 
tempt to perform the following sequence of op- 
erations: 

a. Read and save the PI parameter. 

b. Place a Mark Stack Control Word (MSCW) 
into the stack. 



3-45 





47 


43 


39 


35 


ME3 

31 27 


23 


19 


ACE 

15 


DAE 

1 BE 


SNE 

7 


SM 

3 


50 


46 


M 

42 


EM 

38 


34 


c 

H30 


ME2 

26 


U 
22 


D 

18 


NAQE 
RSE 


TOE 
TOE 


SNM 

6 


HM 

2 


49 


A 

45 


DDR 

41 


37 


33 


29 


MEI 

25 


21 


0) 

17 


SUN 


SBE 


RWM 

5 1 


BE 


9 


48 


44 


40 


36 


32 


N 

28 


24 


20 


ME 

16 


QSE 
~HEA 


8 


TM 

4 


EXC 





Field Bits 

EXC 
MODE WHEN ERROR 
OCCURRED 

HM 2 

SM 3 

TM 4 

RWM 5 

SNM 6 

SNE 7 

SCAN ERRORS 

SBE 9 

TOE 10 

DAE 11 

QSE 12 

SUN 13 

NAQE 14 

NON-SCAN ERRORS 

TOE 10 

IBE 11 

HAE 12 

BE 13 

RSE 14 

ACE 15 

CH NO 21:5 

MEM ADDR 47:20 

ME 16 

MEI, ME2, ME3 27:3 

UD 24:8 



Error 

Exception Bit 
(See bits 2 to 6) 

Home Address Mode 
Start Mode 
Terminate Mode 
Ring Walk Mode 
Scan Mode 

(See bits 9 to 14 or bits 10 to 14) 

(If SNE bit 7=1) 

Scan Bus Parity Error 
Time Out Error (Scan Bus) 
Disk Address Error 
DFO Stack Parity Error 
Storage Unit Not Available 
No Access to DFO Exchange 

(If SNE bit 7=0) 

Time Out Error (Data Service) 
Initiate Busy Channel 
Home Address Illegal Command 
Buffer Register Parity Error 
Residue Error (Memory Address) 

Active Channel Stack Parity Error 

Channel No. (If ACE bit 15=1) 

Memory Address of 10CB (If ACE bit 15=0) 

Memory Error (see bits 25 to 27) 

Memory Error Code (If ME bit 16=1) 

Unit Designate (=0) 



Figure 111-2-2. IOM Fail Word 



c. Place an Indirect Reference Word (IRW) 
into the stack. The IRW references a reserved 
location (D [ ] + 3) in the MCP stack. (When 
in Control Mode 3, the IRW references a re- 
served location (D [ ] + 3) in the Alternate 
D [ ] stack.) 

d. Place the Pi parameter into the stack. 

e. Place a second parameter into the stack 
(the P2 parameter), giving further information 
about the interrupt. 

f. Execute an Enter operator. The fault con- 
trol logic expects to find a Program Control 
Word (PCW) at D [ ] + 3; however, an SIRW, 
an IRW or an IRW chain which points to a 
PCW are possible conditions. 

The two interrupt parameters (Pi and P2) 
that are inserted into the stack supply infor- 
mation describing the interrupt condition. The 



PI parameter provides information concerning 
the type of interrupt, the interrupt priority 
level, and the interrupt class. The P2 
parameter supplies supplementary informa- 
tion about the interrupt condition, such as a 
memory address (memory related interrupts) 
or a copy of the non-present descriptor (pres- 
ence bit interrupts), etc. If P2 is not used by 
the interrupt condition being reported, P2 will 
be set to zero. 

When the interrupt procedure of the MCP is 
entered, the IRW in the stack (step c above) is 
overwritten with a Return Control Word 
(RCW) by the ENTER operator. As with any 
procedure entry, this RCW points to the point 
in the code string to which control is to be re- 
turned following execution of the procedure. 

Figure III-2-3 depicts the stack format just 
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r 



OBJECT . 

PROGRAM ( 

STACK ' 



MCP 
STACK 



°[°]> 



P2 



P1 



RCW 



MSCW 



PROCESSOR ID 



MSCW 



INTERRUPTED OBJECT PROGRAM CODE 



INTERRUPT HANDLING PROCEDURE CODE 



PBR 

PIR 
PSR 



STACK FORMAT AFTER ENTERING THE INTERRUPT PROCEDURE 



Figure II 1-2-3. Stack Format 
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prior to and just after entering the interrupt 
procedure. 

INTERRUPT PROCESSING IN CMI 

When an interrupt is detected while in CMI, 
the CPM advances to CM2 and attempts to en- 
ter the MCP interrupt procedure from its al- 
ternate stack. The new stack is found by using 
the processor number as an index into the 
Stack Vector Array. (This array is pointed to 
by the Stack Vector Descriptor, located at D [ 
] + 2.) The index into the Stack Vector Array 
results in a data descriptor, which points to 
the base of the stack for the new stack. Al- 
ternate stacks are established by the MCP at 
the time of system initialization. 

The Bottom Of Stack Register (BOSR) is set 
to the base address of the new stack, which 
contains the Top Of Stack Control Word 
(TOSCW) for the new stack. A modified move- 
to-stack operation then causes the TOSCW for 
the old stack, the old BOSR setting, and the 
old SNR register (stack number) setting to be 
placed in the top of the new stack. After these 
parameters have been placed, the stack is 
marked, the IRW and the Pi and P2 
parameters are placed in the stack, and the 
MCP interrupt procedure is entered. The stack 
structure just prior to entering the MCP inter- 
rupt procedure is shown in figure III-2-4. 

INTERRUPT PROCESSING IN CM2 

At system initialization time, the MCP 
establishes a special CM3 operating environ- 
ment at the top of memory. This environment 
includes an abbreviated D [ ] stack with its 
own stack vector and an interrupt handler. 
The main memory address of this alternate D 
[ J stack is loaded into the ADZ register of 
all CPM's. When a CPM detects an interrupt 
while in CM2, the CPM advances to CM3, and 
changes to the CM3 environment by setting 
the D [ ] register to the value in ADZ. The 
CPM then attempts to move to its alternate 
stack in the new stack vector (at ADZ +2) and 
enter the new interrupt handler at ADZ +3, as 
described in the previous paragraphs. 

INTERRUPT PROCESSING IN CM3 

If an interrupt is detected while in CM3, it 
is obvious that a recursive interrupt condition 
exists. In such cases the CPM is halted in 
CM4, the most recent interrupt is identified in 
the Fault Condition Register, the HSI flip-flop 
is set, and the CM3 bit is set. 
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Figure 111-2-4. Stack Format Prior to Calling 

Interrupt Procedure While in CM1 (Move Stack 

Operation) 

CONTROL MODE ADVANCEMENT 

Figure III-2-5 illustrates the priority scheme 
for reporting interrupts, the conditions for ad- 
vancing the Control Mode register, and the in- 
terrupt conditions which may be left in the 
Fault Condition register for later servicing. In 
case 1, the Fault Condition register contains 
an Alarm interrupt (first priority) a Stack 
Overflow interrupt (third priority), and may 
also contain Syllable interrupts (second 
priority), Interval Timer interrupts (fifth pri- 
ority), and External interrupts (fourth 
priority). The Alarm interrupt causes the Con- 
trol Mode register to be advanced (from Nor- 
mal to CMI, CMI to CM2, CM2 to CM3, or from 
CM3 to CM4), the Pi parameter reports the 
Alarm interrupt, and the External interrupts 
are still contained in the Fault Condition reg- 
ister (all other interrupts are cleared from the 
register). 

Case 2 shows all priorities of interrupts ex- 
cept Alarm interrupts present in the Fault 
Condition Register. The resultant action is 
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similar to case one, in that the highest priority 
interrupt (Syllable) is serviced first. PI reports 
the Syllable interrupt, the Control Mode regis- 
ter is advanced, and the Stack Overflow and 
External interrupts are still contained in the 
Fault Condition register (in this case the In- 
terval Timer interrupt is also left in the Fault 
Condition register). 

Following entry into the software interrupt 
procedure, the Stack Overflow interrupt is re- 
ported by another PI, the Control Mode regis- 
ter is advanced, the Interval Timer interrupt 
is cleared from the Fault Condition register, 
and the External interrupts are left for later 
servicing. The stack structure for either case 
one or case two is shown in figures III-2-6 and 
III-2-7. 

Case 3 of figure III-2-5 shows a Syllable in- 
terrupt (second priority), an Interval Timer in- 
terrupt (fifth priority), and an External inter- 
rupt (fourth priority) all present in the Fault 
Condition register. In this case, the highest 
priority interrupt present (Syllable) is reported 
in PI, the Control Mode register is advanced, 
and the Interval Timer and External Inter- 
rupts are left for later servicing.(The external 
interrupt is serviced first.) 

Case 4 shows a Stack Overflow interrupt, an 
Interval Timer interrupt, and an External in- 
terrupt present in the Fault Condition regis- 
ter. The Stack Overflow interrupt is reported 
in Pi, the Interval Timer interrupt is cleared 
from the register, and the External interrupt 
is left for later servicing. 

Case 5 shows servicing of an External inter- 
rupt, leaving an Interval Timer interrupt for 
later servicing. Case six shows servicing of an 
Interval Timer interrupt. Notice that these 
two cases can only occur when the CPM is in 
Normal State. (When the CPM advances to 
CM1 and the MCP interrupt procedure is en- 
tered, the CPM operates in Control State and 
the recognition of Interval Timer and Exter- 
nal interrupts is inhibited.) 

ALARM INTERRUPTS (FIRST PRIORITY) 

Detection of an Alarm interrupt causes an 
immediate entry (or reentry) into the fault 
control logic. The Control Mode register is ad- 
vanced and a PI parameter is formed which 
identifies all Alarm interrupts which are pres- 
ent in the Fault Condition register. Syllable 
Dependent interrupts, Stack Overflow Inter- 
rupts, and Interval Timer interrupts (if pres- 
ent) are cleared from the Fault Condition reg- 
ister and the interval timer is disarmed. The 
MCP interrupt procedure is entered. 

SYLLABLE DEPENDENT INTERRUPTS (SECOND 
PRIORITY) 

Detection of a Syllable Dependent interrupt 
(if no Alarm interrupts are present) causes an 
immediate entry (or reentry) into the fault 



control logic. The Control Mode register is ad- 
vanced and a Pi parameter is formed which 
identifies all Syllable Dependent interrupts 
which are present. The MCP interrupt proce- 
dure is entered. 

SPECIAL INTERRUPTS 

STACK OVERFLOW (THIRD PRIORITY). 
All Stack Overflow interrupts are processed by 
the fault control logic and causes advance of 
the Control Mode register. All Stack Overflow 
interrupts do cause a PI parameter reporting 
the interrupt to be formed. Interval Timer in- 
terrupts (if unmasked) are cleared from the 
Fault Condition register and the Interval Tim- 
er is disarmed. The MCP interrupt procedure 
is entered. 

INTERVAL Timer (fifth priority). Interval 
Timer interrupts are cleared (and the interval 
timer is disarmed) when an Alarm or Stack 
Overflow, interrupts is reported. All uncleared 
Interval Timer interrupts cause entry into the 
fault control logic if the mask is set and either 
is in normal state or if executing an IDLE in 
Control state. The Control Mode register is ad- 
vanced to CM1 (from Normal). (Interval Timer 
interrupts are inhibited when the CPM is in 
Control State.) The MCP interrupt procedure 
is entered. 

EXTERNAL INTERRUPTS (FOURTH PRIORITY) 

Although External interrupts can occur at 
any time, these interrupts, with the exception 
of the Egg Timer interrupts, are inhibited 
when the CPM is in Control State. If an Exter- 
nal interrupt occurs when the CPM is in Nor- 
mal State, the Control Mode register is ad- 
vanced to CM1, a PI parameter describing the 
external interrupts is formed, the Interval 
Timer is disarmed, and the MCP interrupt pro- 
cedure is entered. 



MEMORY RELATED INTERRUPTS 

Memory related interrupts include Memory 
Parity errors (MPAR) which are discovered by 
the Communications Unit), Memory Fail 1 
(MF1) errors (which are discovered by the 
MCM and reported to the requestor), invalid 
address errors (which are detected by the 
Communications Unit in its interface with the 
MCM's as an NAM) and Processor Internal er- 
rors (PINT) (which are discovered by the Com- 
munications Unit in its interface with the 
other units of the CPM). It should be noted 
that PINT interrupt can also be set by other 
units in the CPM. These four types of errors 
are differentiated in the Pi interrupt 
parameter. Memory Fail 1 interrupts from all 
MCM's are combined into a single alarm inter- 
rupt, represented by bit 2 in the Fault Control 
register and the Interrupt ID; the identifica- 
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Figure 111-2-5. Interrupt Reporting 
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Figure 111-2-6. Stack Format Before Reentering Interrupt Procedure to Report Stack Overflow 
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Figure 111-2-7. Stack Format After Reentering Interrupt Procedure and Reporting Stack Overflow 



tion of which MCM was involved is given in 
the P2 parameter or in the CPM fail register, 
depending on the type of CU operation being 
performed. Wrong Channel Number and Mem- 
ory Time Out error indications in the CPM fail 
register are combined into a single alarm in- 
terrupt, represented by bit 3 (Invalid Address) 
in the Fault Control register and the Inter- 
rupt ID. Likewise, CU residue (address residue 
error in CA register) and Bad Parity to CU er- 
ror indications in the CPM Fail register are 
combined into a single alarm interrupt, repre- 
sented by bit 6 (Processor Internal) in the 
Fault Control register and the Interrupt ID. 

Explanatory information about these errors 
may be found either in P2 parameter or in the 
CPM Fail register. If P2 is not used, it will be 
set to zero. Details regarding the handling of 
these interrupts are provided in table III-2-2. 



Memory Fail 2 interrupts (single bit errors, 
corrected) are also combined into a single in- 
terrupt in the CPM Fault Condition and Fault 
Mask registers. The identification of the MCM 
involved is given in the CPM Fail register. 
Since the error is corrected, the corrected data 
can be and is used. 

INTERRUPT DESCRIPTIONS 

Interrupts which can occur in the CPM are 
described in the following paragraphs. The in- 
terrupts are described in order of their 
priority. Alarm interrupts are described first, 
Syllable Dependent interrupts second, Special 
interrupts third, and External interrupts last. 

ALARM INTERRUPTS 

Alarm interrupts are caused by conditions 
which were not expected by the CPM. They in- 
form the system of some detrimental change 
in environment. In most cases, Alarm inter- 
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Table 111-2-2. CPM Handling of Memory 
Related Errors 



Source of 

Request for 
Memory Access 

Storage Unit 
fetch (includes 
flashback) 



Storage Unit 
write (no 
flashback) 



Stack Buffer 
empty or purge 



Alarm Interrupts (MPE, MF1, IAE, 
PINT) 

The indication of the error (or error 
word) is queued in place of the 
result of the access (whether in the 
EWR, EU data queue, or the 
associative memory). When the EU 
attempts to use the error word, the 
alarm interrupt occurs. The error 
word is placed in Rl location of the 
EU local storage as the P2 
parameter. 

The alarm interrupt occurs 
immediately. There is no P2 
parameter; rather the explanatory 
information (including the identity of 
the involved MCM) is contained in 
the CPM Fail register. 

Stack Buffer The error word is stored in the stack 

fill buffer and the alarm interrupt does 

not occur until the execution unit 
attempts; to use this word. The error 
word is placed in Rl location of the 
EU local storage as the P2 
parameter. 

The alarm interrupt occurs 
immediately. The reason for this is 
that stack-to-memory transfers are 
initiated only when the Execution 
Unit purges the stack buffer or 
when the Execution Unit attempts to 
push new information into the stack 
and the stack is full; hence, a stack 
empty operation is required. In 
either case, the Execution Unit is 
waiting for the memory access and 
cannot complete the current operator 
until the memory access is completed 
or, as in the error cases, aborted. 

The errcr word is queued in the 
buffer and not reported until the 
Program Control Unit attempts to 
process ;he code string involved. The 
error word is then passed onto the 
Execution Unit as the P2 parameter. 

rupts result from hardware failures. The 
Alarm interrupts cannot be inhibited, and al- 
ways cause entry into the fault control logic. 
The fault control logic terminates the current 
operator, clears the top of stack registers, pre- 
pares the stack (MSCW, IRW, PI, P2), and 
causes the MCP interrupt procedure to be en- 
tered. When an Alarm interrupt is cleared 
from the Fault Condition register, all Syllable 
Dependent interrupts present in the register 
are cleared. The Alarm interrupts are: 

Loop 

Memory Parity 

Memory Fail 1 

Invalid Address (no access) 

Stack Underflow 

Invalid Program Word 

Processor Internal 



Program Buffer 
fetch 



Alarm interrupts generally result in termi- 
nation of the process involved. Exceptions are 
(1) during a halt load when the MCP uses an 
alarm interrupt (invalid address) to determine 
the amount of memory available, and (2) when 
instruction retry by the MCP is successful af- 
ter a Processor Internal interrupt. 

LOOP 

This interrupt occurs when the CPM has ex- 
pended two or in some cases up to five seconds 
in the execution of one operator. This inter- 
rupt can be caused either by a hardware fail- 
ure or by bad data. Should this interrupt oc- 
cur, PIR may not be accurate. 

PARAMETER P2 




PARAMETER PI 




BIT 



Loop Interrupt Parameters 

MEMORY PARITY 

This interrupt occurs if the CPM receives a 
memory word with an even number of l's. 
Should this interrupt occur, PIR points to the 
word containing the operator which initiated 
the interrupt. Supplementary information de- 
scribing the error will be contained in the 
CPM Fail register (see "Memory Related In- 
terrupts"). 

PARAMETER P2 



MCM CONTROL WORD- IF ZERO 
SEE CPM FAIL REGISTER 



PARAMETER PI 



25 




I BIT 



Memory Parity Interrupt Parameters 
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MEMORY FAIL 1 

This interrupt occurs if any of the following 
errors occur: 

a. Data Word parity error 

b. Illegal operation code 

c. Address is for a different Memory Module 
than requested 

d. Data strobe error 

e. Internal control error 

f. Multiple bit data error 

In all of the above cases, supplementary in- 
formation describing the error will be con- 
tained in the MCM Fail register (see "Memory 
Related Interrupts"). 



PARAMETER P2 



MCM CONTROL WORD -IF ZERO 
SEE CPM FAIL REGISTER 



PARAMETER PI 



25 



BIT 




Memory Fail 1 Interrupt Parameters 

INVALID ADDRESS 

This interrupt occurs when the CPM at- 
tempts to access a memory address which is 
not available to the system. The Memory Mod- 
ule may not exist or it may be inoperative. 
Supplementary information is placed in the 
CPM Fail register (see "Memory Related In- 
terrupts"). 



PARAMETER P2 



MCM CONTROL WORD- IF ZERO 
SEE CPM FAIL REGISTER 



STACK UNDERFLOW 

This interrupt occurs if the CPM attempts to 
move the top of stack (S register setting) to an 
address less than the address of the most re- 
cent MSCW (F register setting) during a stack 
adjustment. This could occur as a result either 
of a compiler error or if a hardware control 
failure in executing MKST, EXIT, or MVST 
(all of which change F setting and could calcu- 
late an incorrect address). 

PARAMETER P2 




PARAMETER PI 




BIT 



Stack Underflow Interrupt Parameters 

INVALID PROGRAM WORD 

This interrupt occurs under any of the fol- 
lowing conditions: 

a. An attempt is made to execute a program 
word which does not have a tag of three (or 
tag of if in Edit mode 

b. The Variant code (Escape to 16-bit In- 
struction, VARI) is detected as the second syl- 
lable of a Variant operator. 

c. An attempt is made to execute an 
operator which is considered illegal in Edit 
mode or Vector mode. 

PARAMETER P2 




PARAMETER PI 



25 



BIT 




Invalid Address Interrupt Parameters 



PARAMETER PI 




BIT 



Invalid Program Word Interrupt Parameters 
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PROCESSOR INTERNAL 

This interrupt occurs whenever an internal 
logic failure is detected within the CPM. The 
CPM Fail register wi'll provide additional in- 
formation regarding the failure (see table III- 
2-3). For further information regarding 
memory related Processor Internal interrupts, 
see "Memory Related Interrupts". 

PARAMETER P2 



MCM CONTROL WORD -IF ZERO 
SEE CPM FAIL REGISTER 



PARAMETER PI 




BIT 



Processor Internal Interrupt Parameters 
Table 111-23. Processor Internal Interrupts 

Possible Error Source 



Fail Register 

Indication 

Execution Unit 
Continuity (EUC) 



Execution Unit 
Residue (EUR) 



EU data transfers 

Inconsistent execution of EU 
algorithm 

PCU provided incorrect sequence 
of micro-operators or wrong stack 
count (AFUL, BFUL) to the 
Execution Unit 

C, D, E, F, or G register 

Main or exponent adder, barrel, 
auxiliary storage, T or S or X 
bus, or residue generator 

Extra transfer signal in the use 
of one of the above elements 

Address or PIR from AU storage, 
display buffer, or EWR to the 
Execution Unit 

Residue control logic (use of 
ABC, BOC, BLU, and EWF 

registers) 

Residue error in SH, AL, or R 
register 

Leading zeros residue encoder 

K oi' L registers, or K/L Queue 

Binsiry divide quotient look-head 
logic; 



Table 111-2-3. Processor Internal Interrupts 
(Cont.) 



Fall Register 
Indication 



Execution Unit 
Parity (EUP) 



Program Control 
Unit Error (PER) 



Adder Residue 
(ADD) 



Input Register 
Parity on data 
from CPM (INP) 



Possible Error Source 



Associative memory 

EU local storage 

Stack buffer 

Program buffer 

EU data queue 

EWR, T bus, S bus, C register, or 
EU parity generator 

Parity error in program buffer 

Instruction execute register 

residue error in PIR q 

SSR or AU storage (APIR or 
TIR location) 

AU adder 

PA, PL, PU registers 

Display read register 



S register (for MKST, MVST, and 
RPRR S operations or when 
select address couple (SAC) flip- 
flop (1-8-42) is set.) 

F register (for MKST, ENTR, 
MVST, and RPRR F operations.) 

LOSR (for RPRR, LOSR, and 
MOV operations) 

Display buffer 

Display read register 

Display write register 

AU adder 

Display write residue checker 

Execution Unit 20 bit residue 
generator 

Parity error in storage data 
queue 

Input register 

Output register 

CU parity generator 

Parity error in stack buffer (for 
empty or purge operations) 



3-55 



Table 111-2-3. Processor Internal Interrupts 
(Cont.) 



Fall Register 
Indication 

CU Address 
Residue (CRS) 



Possible Error Source 



Storage Unit related failure: 

AU storage 
Display read register 
AU adder 

Storage input register 
Storage operator queue 
Execution Unit 20 bit residue 
generator 

Memory address register 
CU address register or residue 
checker 

Stack Buffer related failure: 

Stack link register 

CU address register or residue 

checker 

Program buffer related failure: 

AU storage location (PBR or 

TBR) 
Display read register 
AU adder 
PA register 
PU register 

CU address register or residue 
generator 
Remember suspend register 



SYLLABLE DEPENDENT INTERRUPTS 

Syllable Dependent interrupts generally re- 
sult from programming errors. These inter- 
rupts cannot be inhibited, and always cause 
entry into the fault control logic. The fault 
control logic terminates the current operator, 
prepares the stack (MSCW, IRW, PI, P2), and 
causes the MCP interrupt procedure to be en- 
tered. The contents of the top of stack regis- 
ters may or may not be saved, depending upon 
the type of interrupt. 

Syllable Dependent interrupts are divided 
into two classes. Class 1 interrupts (identified 
by the setting of bit 24 of parameter PI) are 
those interrupts in which the values of PIR, 
PSR, PBR, and PDR have not been modified 
by the operator. Class 2 interrupts (identified 
by the setting of bit 23 of parameter PI) are 
those interrupts in which the value of PIR, 
PSR, PBR, and PDR have been changed. Thus, 
class 1 interrupts permit the operator to be 
reexecuted; class 2 interrupts prohibit the op- 
erator from being reexecuted. 

Most Syllable Dependent interrupts occur as 
class 1 interrupts. The only Syllable Depend- 
ent interrupts which can occur as class 2 inter- 



rupts are the Invalid Index, Bottom Of Stack, 
and Sequence Error interrupts. The Syllable 
Dependent interrupts are: 



Memory Protect 
Invalid Operand 
Divide By Zero 
Exponent Overflow 
Exponent Underflow 
Invalid Index 
Integer Overflow 



MEMORY PROTECT 



Bottom Of Stack 
Presence Bit 
Sequence Error 
Segmented Array 
Programmed Operator 
Privileged Instruction 



This interrupt occurs when: 

a. a store, overwrite, read/lock, or string 
transfer operation is attempted using a data 
descriptor that has the read only bit (bit 43) 
set. The operation is terminated before the 
memory access. The data descriptor is used as 
the P2 parameter, except for string transfer. 

b. a store operation is attempted into a word 
in memory that has a tag field representing a 
PCW, RCW, MSCW; or segment descriptor (tag 
= 3, 7). The memory write is discontinued 
when bit 48 is detected in the code word being 
referenced. The flashback is used as the P2 pa- 
rameter. 

PARAMETER P2 



DATA DESCRIPTOR WITH BIT 43 SET, OR MEMORY 

WORD WITH THREE TAGS, OR NUMBER OF ITEMS 

BELOW THE MSCW NEEDED TO GET THE DATA 

DESCRIPTOR 



PARAMETER PI 




BIT 



Memory Protect Interrupt Parameters 



INVALID OPERAND 

This interrupt occurs when the CPM at- 
tempts to execute a valid operator on data 
which is invalid for that operator or attempts 
to execute the invalid operator NVLD. Each 
operator executes checks to insure that control 
words and data meet the necessary require- 
ments of the operator. Should this interrupt 
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occur, PIR and PSR are left pointing to the 
current syllable. 



PARAMETER P2 



PARAMETER P2 



INVALID DATA, OR ZERO 



PARAMETER PI 



24 




BIT 



Invalid Operand Interrupt Parameters 



DIVIDE BY ZERO 

This interrupt occurs when a division 
operation is attempted with the divisor (con- 
tained in the A register) equal to zero. Should 
this interrupt occur, PIR and PSR point to the 
initiating operator, and the divisor and divi- 
dend will be left on the top of the stack (below 
the MSCW, RCW, Pi, and P2). 

PARAMETER P2 




PARAMETER PI 24 



BIT 




Divide By Zero Interrupt Parameters 



EXPONENT OVERFLOW 

This interrupt occurs when the capacity of a 
positive sign exponent field is exceeded for ei- 
ther single or double precision arithmetic re- 
sults. Should this interrupt occur, PIR and 
PSR point to the initiating operator. 




PARAMETER PI 



24 



BIT 




Exponent Overflow Interrupt Parameters 



EXPONENT UNDERFLOW 

This interrupt occurs when the capacity of a 
negative sign exponent field is exceeded for ei- 
ther single or double precision arithmetic re- 
sults. Should this interrupt occur, PIR and 
PSR point to the initiating operator. 

PARAMETER P2 




PARAMETER PI 



24 




BIT 



Exponent Underflow Interrupt Parameters 
INVALID INDEX 

This interrupt occurs if an attempt is made 
to index a descriptor by an amount which is 
less than zero or which is greater than or 
equal to the upper bound (length) in any of the 
following operations: 

a. Occurs Index 

b. Linked List Lookup 

c. Index 

d. Move Stack 

e. Display Update 

f. VALC 

g. Stuffed IRW (pseudo operator) 
h. Index and Load Name 

i. Index and Load Value 
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If this interrupt occurs, the operation is ter- 
minated prematurely. The input operands will 
be left on the top of the stack (below the 
MSCW, RCW, PI, and P2). Except for Display 
Update, all operations in the list above will 
cause PIR and PSR to point to the initiating 
operator. The interrupt occurs as a class 2 in- 
terrupt (bit 23 = 1) if an attempt was made to 
index the Stack Vector Array descriptor (D [ 
] + 2) during a display update operation using 
a stack number which is greater than or equal 
to the length field of the Stack Vector Array 
descriptor. 

Note+ Bit 23 and bit 24 may not both be set 
simultaneously. 



PARAMETER P2 



DATA DESCRIPTOR, MSCW, OR SIRW 



PARAMETER PI 2 4 23 





4> 


• 




BIT 



BOTTOM OF STACK 

This interrupt occurs if a Return operator or 
an Exit operator causes the program stack to 
be cut back to its base. (The F register points 
to the MSCW located at the BOSR setting plus 
1.) The P2 parameter will be a copy of the 
MSCW being cut back. 

This interrupt occurs as a class 2 interrupt 
(bit 23 = 1). 



PARAMETER P2 



MSCW BEING CUT BACK 



PARAMETER PI 



23 



BIT 



Note: Bit 23 and Bit 24 may not be set si- 
multaneously. 



Invalid Index Interrupt Parameters 
INTEGER OVERFLOW 

This interrupt occurs upon detection of the 
attempted use of an operand which exceeds 
the maximum integer value (2 M -1) by an oper- 
ator which requires an integer. The following 
is a partial list of operators which may cause 
this interrupt to occur: 

a. Integer Divide 

b. Integerize Truncate 

c. Integerize Rounded 

d. Occurs Index 
PARAMETER P2 




PARAMETER PI 



24 



BIT 




Integer Overflow Interrupt Parameters 



Bottom Of Stack Interrupt Parameters 
PRESENCE BIT 

This interrupt occurs when an attempt is 
made to access a word or group of words which 
are not present in main memory. All operators 
that access memory with descriptors may be 
interrupted with this interrupt. The interrupt 
occurs if an attempt is made to reference 
memory through a descriptor which has the 
presence bit (bit 47) reset, indicating that the 
descriptor points to words which are not pres- 
ent in main memory. There are two classes of 
presence bit interrupt conditions; data depend- 
ent and procedure dependent. 

DATA DEPENDENT. Data dependent pres- 
ence bit interrupt conditions occur when the 
CPM is seeking data from within its current 
addressing environment. In all cases except 
Value Call, recovery is achieved by re-execu- 
ting the operator upon return from the MCP 
interrupt procedure. The MCP interrupt proce- 
dure makes the absent words present before 
return is made to the interrupted program. To 
permit this reexecution, the PIR and PSR set- 
tings for the current operator are saved in the 
RCW. Value Call always sets this RT bit for 
data dependent interrupts; however, Value 
Call never sets this RT bit for procedure de- 
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pendent interrupts. Value Call or pseudo value 
call will always turn on the VS bit (bit 39) and 
cause the V bit in the MSCW to be turned on. 
Figure III-2-8 illustrates the PIR, PSR, Exit/ 
Return, RT, VS, and RE bit relationships in 
the various presence bit interrupt conditions. 

ACCIDENTAL ENTRY. Procedures which 
have been entered accidentally during the 
VALC operator also require special 
consideration for the manipulation of PIR and 
PSR settings for the RCW. The VALC operator 
is completed after the return operator 
mechanism when returning from an acciden- 
tally entered procedure. A pseudo value call 
operator provides the facility to continue 
searching an IRW or data descriptor chain un- 
til an operand is located. The pseudo value call 
operator is activated at the end of a normal 
return operator if the V bit of the MSCW had 
been set. The V-bit is set when either a VALC 
or pseudo value call operator enters a proce 
dure accidentally. If a not present segment de 
scriptor causes an interrupt during a return 
from an accidental entry of value call, a pseu 
do RT bit (Bit 45) is turned on in PI so the 
presence bit procedure will finish with a re 
turn instead of an exit if the VS (Bit 39) is also 
on. The RT bit and pseudo RT bit are used by 
the software to execute the proper code. The V 
bit is used by the hardware to change the re 
turn into a pseudo value call so the IRW or 
data descriptor chain may be chased. 

PIR and PSR values, pointing to the next 
operator syllable, are inserted into the RCW 
for VALC while the PIR and PSR values from 
the old RCW are inserted into the RCW for a 
value call pseudo operator. 

All other operators which may incur acciden 
tal entries are restarted; therefore, the PIR 
and PSR settings which point to the current 
operator syllable are saved in the RCW. The V- 
bit is set to zero. 

PROCEDURE DEPENDENT. Procedure de- 
pendent interrupts occur when the CPM is at- 
tempting to enter a new addressing environ- 
ment, or attempting to return to an old ad- 
dressing environment. These interrupts occur 
during display update, and also when trying to 
process a non-present segment descriptor. Re- 
covery is achieved by the Exit operator or the 
Return operator after the MCP interrupt pro- 
cedure has made the referenced environment 
present. Because the CPM has not yet fetched 
the first operator of the new procedure when 
this interrupt occurs, the PIR and PSR set- 
tings from the PCW (for entry) or the RCW 
(for return) are stored in the RCW which is 
made when the MCP interrupt procedure is 



entered. Thus, when the reference environ- 
ment is made present, the entry or return is to 
the referenced environment. 

PROGRAM RESTART. Following a Presence 
Bit interrupt, a program may be restarted ei- 
ther by executing a Return operator or an Ex- 
it operator. The Return operator must return 
either an IRW or a Data Descriptor. The RT 
bit of the PI parameter (bit 46) indicates to 
the MCP interrupt procedure whether to per- 
form an Exit operator (bit 46 is reset) or a Re- 
turn operator (bit 46 is set) when returning to 
the interrupted procedure. 

PARAMETER P2. During the execution of 
certain string operators, if a Presence Bit in- 
terrupt occurs the P2 parameter may contain 
a number which indicates the number of items 
below the MSCW which are needed by the 
string operator. 

PARAMETER P2 



SEGMENT DESCRIPTOR, OR DATA 
DESCRIPTOR, OR IRW, OR NUMBER 
OF ITEMS BELOW THE MSCW THAT 
ARE NEEDED BY THE STRING OPERATOR 



PARAMETER PI 2 4 




BIT 



Presence Bit Interrupt Parameters 



SEQUENCE ERROR 

This interrupt occurs if an indirect reference 
encounters an invalid condition or reference 
sequence. Generally, this interrupt is caused 
either by a hardware error or a systems soft- 
ware error, and the MCP will terminate the 
program which generated the interrupt. The 
interrupt can occur as a class 2 interrupt (bit 
23 = 1) only under the following conditions: 

a. When a word other than a Segment De- 
scriptor is fetched relative to the PDR during 
the final algorithm for the Enter, Exit, or Re- 
turn operators. 

b. When the F register points to a word 
which is not an MSCW at the beginning of 
execution of the Exit or Return operators. 

c. When tracing back through the DF links 
of an MSCW chain (DF locates the preceding 
MSCW in the stack) during an Exit, Return, or 
Move Stack operation and a word which is not 
an MSCW is fetched. 
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Figure 111-2-8. Presence Bit Interrupt Chart 



d. When a word which is not a Segment De- 
scriptor is fetched relative to the PDR during 
a Dynamic Branch operator execution. 

PARAMETER P2 




PARAMETER PI 



24 23 9 



BIT 




Sequence Error Interrupt Parameters 

SEGMENTED ARRAY 

This interrupt occurs when a string operator 
attempts to index beyond the end of the cur- 
rent segment of a segmented array. Arrays in 
main memory may be segmented into groups 
of 256 words each, bounded on both ends by 
memory links. The memory link words are cre- 
ated by the MCP with the memory protect bit 
(bit 48) set. During string operations, each 
word read from memory is checked to see if bit 
48 is set. If such a word is referenced, the Seg- 
mented Array interrupt will occur. The P2 pa- 
rameter will indicate how many words (in the 
stack below the MSCW, RCW, Pi, and P2) are 
needed to restart the operation after the new 
segment of the array has been made available 
in main memory. 



PROGRAMMED OPERATOR 

This interrupt occurs if the CPM attempts to 
execute an operator code which is not cur- 
rently assigned. The Programmed Operator in- 
terrupt acts as a communicate operator to the 
MCP, and allows the MCP to simulate the ac- 
tion of the operator programmatically, if de- 
sired. All unassigned operator codes cause this 
interrupt. (None of the unassigned operator 
codes cavise Loop, Invalid Program, or Invalid 
Operand interrupts. Scan In Time Of Day 
Clock is an assigned operator: any other 
variation of Scan In causes the Invalid Oper- 
and interrupt.) 

PARAMETER P2 




Programmed Operator Interrupt Parameters 



PRIVILEGED INSTRUCTION 

This interrupt occurs if an attempt is made 
to execute a Control State operator while the 
CPM is in Normal State. The Control State op- 
erators are: 

a. Set Interval Timer (SINT) 

b. Inhibit Parity (IGPR) 

c. Set Memory Inhibits (SINH) 

d. Set Memory Limits (SMLT) 



PARAMETER P2 



NUMBER OF ITEMS BELOW THE 
MSCW NEEDED TO RESTART OPERATION 



PARAMETER P2 




PARAMETER PI 



24 IC 




BIT 



PARAMETER PI 



24 II 



BIT 




Segmented Array Interrupt Parameters 



Privileged Instruction Interrupt Parameters 
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SPECIAL INTERRUPTS 

Special interrupts take third priority for 
processing. There are just two Special inter- 
rupts: Stack Overflow and Interval Timer. 

STACK OVERFLOW 

This interrupt occurs when the Stack Con- 
troller senses the use of the highest address 
allotted for the stack of the program (the S 
register and the Limit of Stack register 
(LOSR) point to the same address). The MCP 
interrupt procedure may either allocate a larg- 
er stack area, or it may terminate the pro- 
gram. If the current operator has not been 
completely executed, PIR and PSR are 
changed to point to the operator. 

PARAMETER P2 




PARAMETER PI 



22 



BIT 



Stack Overflow Interrupt Parameters 

INTERVAL TIMER 

This interrupt occurs if the value in the 
hardware interval timer is zero and the inter- 
val timer is armed. The timer is armed and an 
initial value is stored by the Set Interval Tim- 
er operator (SINT). The count in the timer is 
decreased every 512 microseconds until the 
count reaches zero or until the timer is reset. 
If the timer is still armed when the count 
reaches zero, the interrupt occurs. The 
maximum interval to which the timer can be 
set is one second. This interrupt is used by the 
MCP to insure that no process can control a 
CPM for more than one second without giving 
the MCP a chance to regain control of the 
CPM. 

PARAMETER P2 




PARAMETER PI 



22 



BIT 



EXTERNAL INTERRUPTS 

External interrupts are used to inform the 
MCP of changes in external environment, and 
also to permit communications between re- 
questor modules (CPM or IOM). Normally, 
these interrupts result in the momentary in- 
terruption of a program while the interrupt is 
handled or recorded by the MCP. Following 
the handling of the interrupt, the program is 
continued. The External interrupts are: 

Channel (0 thru 7) 
IOM Error (0 thru 7) 
Memory Fail 2 
Egg Timer 

CHANNEL INTERRUPT 

This interrupt may be generated by any of 
the eight possible requestor modules (CPM or 
IOM). The interrupt identification (parameter 
PI) indicates the source of the interrupt. This 
interrupt may be generated to indicate an ex- 
pected event (such as 10 Complete) or it may 
be generated by the Interrupt Channel N op- 
erator (which allows any CPM to interrupt any 
requestor module). 

PARAMETER P2 




PARAMETER PI 



21 7 6 5 43 2 I BIT 



CHANNEL 7- 
CHANNEL 6- 
CHANNEL b- 
CHANNEL 4- 
CHANNEL 
CHANNEL 
CHANNEL I- 
CHANNEL 0- 



00 



3- 
2- 



Interval Timer Interrupt Parameters 



Channel Interrupt (0-7) Parameters 

IOM ERROR INTERRUPT 

This interrupt may be generated by any of 
the IO modules in the system. The interrupt 
identification (parameter PI) indicates the 
channel (0 thru 7) to which the IOM is con- 
nected. This interrupt is used to report errors 
detected by an IOM which are not device re- 
lated. If possible, the IOM will link a dummy 
IOCB into the status queue (RESULTQ). The 
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dummy IOCB will contain a Result Descriptor 
which will further describe the error. Other- 
wise, the Fail Result Descriptor will be placed 
at Home Address (HA) + 5. 

PARAMETER P2 




PARAMETER P2 




PARAMETER PI 



21 16 



BIT 




PARAMETER PI 



21 15 1413 12 1 1 10 9 8 



BIT 



IOM ERROR 
IOM ERROR 
IOM ERROR 
IOM ERROR 
IOM ERROR 
IOM ERROR 
IOM ERROR 
IOM ERROR 



IOM ERROR (0-7) Interrupt Parameters 

MEMORY FAIL 2 

This interrupt occurs if a Memory Control 
Module detects and corrects a single-bit error. 
It is transmitted from the MCM (with the cor- 
rected data) to the requestor module (CPM or 
IOM). The MCM Fail register contains the ab- 
solute address and the bit number of the word 
in error. The identification of the MCM in- 
volved is contained in the CPM Fail register. 



Memory Fail 2 Interrupt Parameters 

EGG TIMER INTERRUPT 

This interrupt occurs if the Egg flip-flop in 
the CPM is not reset every 8 to 16 seconds by 
the MCP. This interrupt is used by the MCP to 
prevent the CPM from looping while in the 
control state. 



PARAMETER P2 



ZERO 



PARAMETER P1 




BIT 



Egg Timer Interrupt Parameters 
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SECTION 3 



OPERATORS 



INTRODUCTION 

Operators are machine language code gener- 
ated by the compiler and stored by the master 
control program in memory in the area allo- 
cated to program segments. (Program seg- 
ments contain no data and are not modified by 
the processor as the program is executed.) Pro- 
gram segments are sequences of instructions 
which are moved by the program control unit 
as 52-bit words from memory into the program 
buffer. Parity is checked on all 52-bits of each 
program word as it is brought to the program 
buffer. 

The program buffer, a 32-word, 60-bit IC 
memory within the processor, locally main- 
tains enough code to keep the processor busy 
at all times. The buffer may contain 8, 16, 24, 
or 32 program words. A request is generated 
to replenish the buffer by fetching 8 words at 
a time whenever the read pointer is within 
two words of the writer pointer. 

The buffer is interleaved so that it alter- 
nately stores all odd-address words from mem- 
ory in one division of the buffer and stores all 
even-address words in the other division. 

Each division consists of four segments each 
of which contains four words as shown in Fie- 
ure III-3-1. 



Each program word consists of 48 bits, 3 tag 
bits, and an overall parity bit. Since informa- 
tion will be extracted from the program buffer 
in syllable form there is no way to check over- 
all parity. Therefore, as the program word is 
parsed into six 8-bit syllables while being 
loaded into the program buffer, parity is also 
generated on each syllable of the word and 
stored in the buffer with each word. The 
parity of each syllable; can thus be checked 
and the integrity of the program word main- 
tained. Figure III-3-2 illustrates the format of 
the program buffer word. 

Since the B 7700 allows operators to overlap 
word boundaries, the program buffer is read 
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Figure 111-3-1. Format of Program Buffer Word 
Storage 

out serially. Two words are read out of the 
buffer at the same time, one even address (in- 
dicated by the PEB pointer) and one odd (indi- 
cated by the POB pointer). These pointers to- 
gether with the odd/even flip-flops (OEA, 
OEB, and OEC) then select which of the two 
words will be left-justified in the barrel switch 
of the program unit. (These pointers may also 
be adjusted to facilitate a local branch or en- 
try into an edit table.) The syllables will then 
be processed left to right in sequence. 

An instruction may be either a Value Call, a 
Name Call, or an operator. The two high-order 
bits (e.g., bits 7 and 6 in Figure III-3-2) of each 
instruction determine the type of instruction 
to be executed. 



Instruction Decode Table 



Instruction 


Identification (Bits 7 


No. of 


Type 


& 6) 


Syllable 


Value Call 


00 


2 


Name Call 


01 


2 


Operator 


lx 


1 to 12 



Function 



Brings an operand into the stack 
Brings an IRW into the stack 
Performs the specified operation 



3-65 



TAG 



OA P 





SYLLABLE 




SYLLABLE 




SYLLABLE 




SYLLABLE 




SYLLABLE 




SYLLABLE 









1 




2 




3 




4 




5 


S P 


47 43 
46 42 


S P 


39 35 
38 34 


S P 


31 27 
30 26 


S P 


23 19 
22 18 


S P 


15 11 
14 10 


S P 


7 3 
6 2 












45 41 




37 33 




29 25 




21 17 




13 9 




5 1 




44 40 




36 32 




28 24 




20 16 




12 8 




4 



41051 



Figure 111-3-2. Program Buffer Word Format 



Value Call is a two-syllable instruction that 
brings an operand from memory into the top- 
of -stack. A concatenation of the two Value Call 
syllables gives a 14-bit address couple. If the 
referenced memory location is an indirect ref- 
erence word or a data descriptor, additional 
memory accesses are made until the operand 
is located. The operand is then placed in the 
top-of-stack register. The operand may be ei- 
ther single-precision or double-precision, caus- 
ing either one or two words to be loaded into 
the stack. 

Name Call builds an indirect reference word 
in the stack. Stack adjustment takes place so 
that the top-of-stack is empty. The six low-or- 
der bits of the first syllable for this operator 
are concatenated with the eight bits of the fol- 
lowing syllable to form a 14-bit address couple. 
The address couple is placed, right-justified 
into the top-of-stack; the remainder of the top- 
of-stack register is set to zero. The tag field is 
set to 001 and the register is marked full. 

Operators vary from 1 to 12 syllables in 
length. The first syllable of each operator indi- 
cates the number of additional syllables form- 
ing the operator. 

Operators work on data as either full words 
(48 data bits plus 3 tag bits) or as strings of 
data characters. Word operators work with op- 
erands (single-or double-precision) in the top of 
the stack. 

String operators are used for transferring, 
comparing, scanning, and translating strings 
of digits, characters, or bytes. In addition, a 
set of micro-operators (EDIT Mode operators) 
provides a means of formatting data for input/ 
output. String operators and edit mode 
operators use source and destination pointers 
located in the stack to set hardware registers. 

In some of the string operators the source 
pointer may not be used. In this case, an oper- 
and may be in the stack; its characters are cir- 
culated as it is being used. String operators 



have an optional update function, producing 
updated source and destination pointers and 
counts. 

If both the source and destination descrip- 
tors have size fields equal to zero, the size reg- 
isters indicate 8-bit character size. When both 
a source and destination are required and the 
size field of one is equal to zero and the other 
is not, then the size field of the non-zero de- 
scriptor is used. 

If neither size field is equal to zero and the 
size fields are not equal and the operator is 
not Translate or Transfer Words, the invalid- 
operand interrupt is set and the operator is 
terminated. The size field is considered equal 
to zero when the source is an operand. 

In the B 7700 Systems operands may be 
used to represent either numeric or logical in- 
formation. An operand may be a single-preci- 
sion (SP) operand or double-precision (DP) op- 
erand. Memory word tag bits (bits 50, 49, and 
48), when 000, designate an SP operand and, 
when 010, designate a DP operand. 

Logical operands may be either true (ON) or 
false (OFF). Logical values are the result of 
Boolean operations or relational operations. 
Relation operators generate a logical value as 
the result of an algebraic comparison of two 
arithmetic expressions. Bit contains the 
logical value. Relational operators set bit 0, 
and conditional operators use bit for the de- 
cision. Logical (Boolean) operators consider 
each bit from 47 to as an individual logical 
value and operate on the whole operand. 

GROUPING OF OPERATORS 

Operators may be identified by name, mne- 
monic, or hexadecimal code. In this document 
to facilitate reference to the description of the 
operators, the operators are listed in the ap- 
pendix in two ways: alphabetically by mne- 
monic, and sequentially by hexadecimal code. 
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In each case the page number of the operator 
description is given. 

When describing operators, considerable re- 
dundancy is eliminated by grouping operators 
with similar functions and only describing 
their differences. Also, for convenience of the 
user, operators used for related manipulations 
(e.g., arithmetic operators i.e. ADD, SUBT, 
MULT, DIVD, etc.) are described sequentially. 

As shown in Figure 1 1 1-3-3 all central proc- 
essor program operators are grouped into one 
of four modes: primary (P), variant (V), edit 



(E), or vector (Z). Several operators are classed 
as universal (U) because they can operate in 
any mode. (The letters in the above parenthe- 
ses are used in this document as a mode-iden- 
tifier prefix before the hexadecimal code asso- 
ciated with each operator; e.g., (P) 80 indicates 
a primary mode operator and 80 is the 
hexadecimal code for the ADD operator.) In 
this document, the operator descriptions are 
grouped by mode and preceding each group of 
descriptions for each mode there is a listing 
giving the order of specific operator descrip- 
tions. 
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Figure 111-3-3. B 7700 CPM Program Operator Hexadecimal Code Assignments 
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The most frequently used operators are 
called primary mode operators. Each of the 
other modes is entered by first executing cer- 
tain operators in primary mode. The 
"operator" portion of the primary mode 
operators begins with the first syllable and 
may extend for several syllables. 

Primary mode operators are described in 
this document in the following groups: arith- 
metic, bit, branch, compare, enter edit mode, 
enter vector mode, index and load, input con- 
vert, literal call, logical, pack, relational, scale, 
stack, store, string, string transfer, subrou- 
tine, transfer, type-transfer, miscellaneous, 
and universal. (In several cases a variant 
mode operator is conveniently described with a 
group of primary mode operators.) 

Variant mode operators are less frequently 
used than primary mode operators and extend 
the number of hexadecimal codes available to 
identify the operators. Variant mode operators 
require two syllables. The first syllable of a 
variant mode operator has the hexadecimal 
code 95 which is the primary mode operator 
called Escape to 16-Bit Instruction (the mne- 
monic for this operator is VARI). The second 
syllable then gives the actual variant mode op- 
eration to be performed. The variant mode op- 
erators are described in this document in the 
following groups: scan, scan while, tag field, 
unpack, miscellaneous, operators exclusive to 
the B 7700, and universal operators. 

Edit mode operators perform edit functions 
(such as insert, move, and skip) on strings of 
data being prepared for output. The Edit mode 
is entered from the primary mode via one of 
the enter edit operators (EXSD, EXSU, EXPU, 
TEED, or TEEU). Subsequent edit operators 
follow as either single micro operators in the 
program string or as edit operators in a 
separate table which is executed as a program 
string. In edit mode the program buffer 
memory is reduced to 16 words (total available 
area) for processing the edit operators; the 
other 16 words contain the primary program 
syllables. 

The basic B 7700 architecture avoids index 
registers in order to facilitate block or proce- 
dure entries. Although this improves the ma- 
chine's overall performance, it does impede 
processes of an iterative nature such as the 
ordinary handling of arrays. The B 7700 over- 
comes this difficulty with vector mode 
operation (a variation of string operator edit 
mode) which permits successive accesses to the 
elements of an array by using the source, des- 
tination, and table pointer areas of the IC 
memory as index registers and by improved 
loop control. Vector mode hardware provides 



additional register capabilities and permits op- 
erators to be generated by the compilers to ef- 
fect improved handling of vectors. 

Vector mode is entered from primary mode 
by using either of two operators: a Single 
Word Vector Mode (VMOS) entry or Multiple- 
Word Vector Mode (VMOM) entry. The two en- 
ter vector operators assign addresses to the in- 
dex registers and perform either a VMOS or a 
VMOM operation. Single-Word Vector Mode 
forces an automatic one-word branch back- 
ward while the processor is in vector mode. 
The Multiple-Word Vector Mode uses the auto- 
matic local branch point detection. The 
operators Vector Branch and Vector Exit are 
used only in the Multiple-Word Vector Mode 
and provide control of program iterations and 
exiting. Twenty-four vector stack operators 
link the top of stack with the word addressed 
by a specific IC register, thus enabling direct, 
indexable transfers between memory and the 
top of stack. Forty operators are permitted for 
vector and matrix manipulations. 

In vector mode certain limitations must be 
considered; for example, the processor is in 
control state and cannot be interrupted to 
service other needs. The arrays manipulated 
by vector mode cannot be segmented and must 
be present in their entirety while in vector 
mode. Therefore, the use of vector mode in a 
general multiprocessing environment must 
necessarily be restricted; nevertheless, it pro- 
vides a powerful tool for a particular class of 
problems. 

Detection of an invalid operator condition 
terminates the operator, and an invalid 
operator interrupt is set in the processor inter- 
rupt register. The processor will proceed to 
process the interrupt whether it is in normal 
state or control state. 

Invalid instructions are detected by the fol- 
lowing methods: 

1. Testing for unassigned operator codes. In 
the B 7700 all unassigned operators cause a 
programmed operator interrupt. 

2. Testing for any value other than 011 in 
bit positions 50, 49, and 48 of any program 
word (an attempt to execute something which 
is not code). This results in an invalid program 
word interrupt except when in table mode 
which allows a tag or a tag 3. 

3. Testing for an invalid operator function; 
for example, an attempt to dial to a non-exi- 
stent bit. This results in an invalid operand in- 
terrupt. 

Bit 48 of each word in main memory is a 
memory protect bit. This bit is ON in all pro- 
gram words, indirect reference words, data de- 
scriptors, program descriptors, main memory 
storage links, and processor-generated control 
words. 
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Except for stack pushdowns and the overwr- 
ite operators an attempt by a processor to 
write into a location when the contents of that 
location has the memory protect bit set will 
cause a memory-protect interrupt to be set in 
the processor interrupt register. The overwrite 
operators will overwrite whatever is in the ad- 
dressed area. When the string or edit 
operators attempt to access the source or des- 
tination areas they will get a segment array 
interrupt but when they attempt to access a 
table they will get a memory-protect interrupt. 



PRIMARY MODE OPERATORS 

Primary mode operators may consist of as 
many as seven syllables but the first syllable 
defines the operation. 

ARITHMETIC OPERATORS 

Dyadic arithmetic operators require two op- 
erands in the top-of-stack storage. These oper- 
ands are combined by the arithmetic process 
specified and are replaced with the resulting 
operand. Both operand:? may be either single- 
precision, double-precision, or intermixed 
types. The specified arithmetic process adapts 
automatically to the environment: a single- 
precision process is invoked if both operands 
are of the single-precision type and a double- 
precision process is invoked if either operand 
is of the double-precision type. Each double- 
precision operand occupies two words. The sec- 
ond word of the operand is an extension of the 
first word of the operand, i.e., the mantissa of 
the first word of the operand may be an inte- 
ger but the mantissa of the second word is al- 
ways a fraction. 

Add, subtract, multiply, and integer divide 
operations with two integer operands yield an 
integ;er result if no overflow occurs. If one or 
both operands are noninteger or if the result 
overflows, the result is noninteger. 

ADD (ADD) (P)80 

The Add operator causes the two top-of-stack 
operands to be added algebraically and the 
sum to be left in the top-of-stack. 

SUBTRACT (SUBT) (P)81 

The Subtract operator causes the top-of- 
stack operand to be algebraically subtracted 
from the second operand in the stack and the 
result to be left in the top-of-stack. 

MULTIPLY (MULT) (P)82 

The Multiply operator causes the two top-of- 
stack operands to be algebraically multiplied 
and the product to be left in the top-of-stack. 



EXTENDED MULTIPLY (MULX) (P)8F 

The Extended Multiply operator causes the 
two top-of-stack operands to be algebraically 
multiplied and a double-precision product to be 
left in the top-of-stack. 

DIVIDE (DIVD) (P)83 

The Divide operator causes the second oper- 
and in the stack to be algebraically divided by 
the top-of-stack operand the quotient to be left 
in the top-of-stack. If the mantissa of the sec- 
ond operand in the stack is zero, the exponent 
and quotient are set to zero. If the top-of-stack 
mantissa is zero, the divide-by-zero interrupt 
is set. In either case the operation is termi- 
nated. 

INTEGER DIVIDE (IDIV) (P)84 

The Integer Divide operator causes the sec- 
ond operand in the stack to be algebraically di- 
vided by the top-of-stack operand and the inte- 
ger part of the quotient to be left in the top- 
of-stack in integer form. If the mantissa of the 
second operand in the stack is zero, the expo- 
nent and quotient are set to zero. If the top- 
of-stack mantissa is zero, the divide-by-zero in- 
terrupt is set. In either case the operation is 
terminated. 

REMAINDER DIVIDE (RDIV) (P)85 

The Remainder Divide operator causes the 
second operand in the stack to be algebraically 
divided by the top-of-stack operand to develop 
an integer quotient. The remainder of this di- 
vision is left in the top-of-stack. If this remain- 
der is an integral value, it is in the form of an 
integer. If the mantissa of the second operand 
in the stack is zero, the exponent and quotient 
are set to zero. If the top-of-stack mantissa is 
zero, the divide-by-zero interrupt is set. In ei- 
ther case the operation is terminated. 

INTEGERIZE, TRUNCATED (NTIA) (P)86 

The Integerize (Truncated) operator converts 
the top-of-stack operand to an integer without 
rounding. If the operand cannot be inte- 
gerized, i.e., the exponent is greater than the 
number of leading zeros in the operand. The 
integer-overflow interrupt is set and the oper- 
ation is terminated. 

INTEGERIZE, ROUNDED (NTGR) (P)87 

The Integerize (Rounded) operator converts 
the top-of-stack operand to an integer with 
rounding. Rounding takes place if the absolute 
value of the fraction is greater than 4. If the 
operand cannot be integerized, i.e., the expo- 
nent is greater than the number of leading 
zeros in the operand or a non-integer results 
from the rounding operation, the integer-over- 
flow interrupt is set and the operation is ter- 
minated. 
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INTEGERIZE ROUNDED, DOUBLE PRECISION (NTGD) 

(V)87 

The Integerize (Rounded, Double Precision) 
operator converts the top-of-stack operand to a 
double-precision integer (exponent +13) with 
rounding. 

BIT OPERATORS 

Bit operators set or reset bits in the top-of- 
stack or in the second item in the stack. 

BIT SET (BSET) (P)96 

The Bit Set operator sets a bit in the top-of- 
stack. The bit set corresponds to the value of 
the bit specified by the second syllable of the 
operator. If the program syllable defining the 
bit to be set has a value greater than 47, the 
invalid-operand interrupt is set and the 
operation is terminated. 

DYNAMIC BIT SET (DBST) (P)97 

The Dynamic Bit set operator sets a bit in 
the second item in the stack. The bit set corre- 
sponds to the value of the bit specified by the 
top-of -stack operand. If the word in the top-of - 
stack is not an operand an invalid-operand in- 
terrupt is set and the operation is terminated. 
The word is integerized before it is used as a 
bit number. If after being integerized the op- 
erand is less than zero or greater than 47, an 
invalid-operand interrupt is set and the 
operation is terminated. 



BIT RESET (BRST) (P)9E 

The Bit Reset operator resets a bit in the 
top-of-stack. The bit reset corresponds to the 
bit specified by the second syllable of the pro- 
gram operator. If the program syllable defin- 
ing the bit to be reset has a value greater 
than 47, an invalid-operand interrupt is set 
and the operation is terminated. 

DYNAMIC BIT RESET (DBRS) (P)9F 

The Dynamic Bit Reset operator resets a bit 
in the second item in the stack. The reset bit 
corresponds to the value of the bit specified by 
the top-of-stack operand. If the word in the 
top-of-stack is not an operand an invalid-oper- 
and interrupt is set and the operation is termi- 
nated. The word is integerized before it is used 
as a bit number. If, after being integerized, 
the operand is less than zero or greater than 
47, an invalid-operand interrupt is set and the 
operation is terminated. 

CHANGE SIGN BIT (CHSN) (P)8E 

The Change Sign Bit operator complements 
(changes from 1 to or from to 1) the sign 
bit (bit 46) of the top-of-stack operand. 



COUNT BINARY ONE'S (CBON) (V)BB 

The Count Binary One's operator counts the 
number of binary ones in the information part 
of the word in the top-of-stack and places this 
count in the top-of-stack. 

LEADING ONE TEST (LOG2) (V)8B 

The Leading One Test operator locates the 
most significant information bit of the word in 
the top-of-stack. The number of that bit plus 
one is placed in the top-of-stack. If a one bit is 
not located, a zero is placed in the top-of-stack. 

BRANCH OPERATORS 

Branch instructions function to break the 
normal sequence of serial instruction fetches. 
Branching may be either relative to the base 
address of the current program segment or to 
a location in some other program segment. 
Branch operators may be conditional or uncon- 
ditional. Branch addresses are always checked 
for possible residency in the local program 
buffer. 

BRANCH UNCONDITIONAL (BRUN) (P)A2 

The Branch Unconditional operator replaces 
the contents of the program index register 
(PIR) and the program syllable register (PSR) 
with the next two syllables from the program 
string. The two syllables following the actual 
operator syllable provide the new PIR and 
PSR settings: the three high-order bits are 
placed in the PSR and the next 13 low-order 
bits are placed in the PIR. 

BRANCH ON TRUE (BRTR) (P)A1 

If the low-order bit of the top-of-stack word 
is a one, the Branch on True operator replaces 
the contents of the program index register and 
the program syllable register with the next 
two syllable positions and the program contin- 
ues in sequence. Otherwise, the PIR and PSR 
are advanced three syllable positions and the 
program string continues in sequence. 

BRANCH ON FALSE (BRFL) (P)AO 

If the low-order bit of the top-of-stack word 
is a zero, the Branch on False operator re- 
places the contents of the program index reg- 
ister and the program syllable register with 
the next two syllables from the program 
string. Otherwise, PIR and PSR are advanced 
three syllable positions and the program 
string continues in sequence. 

DYNAMIC BRANCH UNCONDITIONAL (DBUN) (P)AA 

If the top-of-stack word is either a program 
control word or an indirect reference to a 
PCW, the Dynamic Branch Unconditional op- 
erator branches to the specified syllable of the 
program segment. 
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If the top-of-stack word is an operand, the 
program index register and program syllable 
register are set according to the contents of 
this operand as follows: The operand is made 
into an integer. If it is negative or if it is 
greater than 16384 the invalid-index interrupt 
is set and the operation is terminated. If bit 
zero of the operand is zero, PSR is set to zero; 
otherwise, if bit zero of the operand is one, 
PSR is set to three. The next higher-order 13 
bits are placed in the PIR. 

DYNAMIC BRANCH TRUE (DBTR) (P)A9 

If the low-order bit of the second word in the 
stack is a one and the top-of-stack word is a 
program control word (PCW) or an indirect ref- 
erence to a PCW, the Dynamic Branch True 
operator will cause a branch to the specified 
syllable in the program segment. Otherwise, a 
one is added to the PIR and PSR and the pro- 
gram continues in sequence. 

If the low-order bit of the second word in the 
stack is a one and th€> top-of-stack word is an 
operand, PIR/PSR are replaced from this oper- 
and as in the DBUN operator. Otherwise, PIR 
and PSR are advanced and the program string 
continues in sequence. 



DYNAMIC BRANCH FALSI! (DBFL) (P)A8 

If the low-order bit of the second word in the 
stack is a zero, and the top-of-stack word is a 
program control word or an indirect reference 
to a PCW, the Dynamic Branch False operator 
causes a branch to the specified syllable of the 
program segment. Otherwise, the PIR/PSR are 
continued in sequence. 

If the low-order bit of the second word in the 
stack is a zero and the top-of-stack word is an 
operand, PIR/PSR are replaced from this oper- 
and as in the DBUN operator. Otherwise, PIR 
and PSR are advanced and the program string 
is continued in sequence. 



STEP AND BRANCH (STBR) (P)A4 

The Step and Branch operator is initiated 
with a reference to either a step index word 
(SIW) or an operand in the top-of-stack. The 
target item may be reached through a chain of 
indirect reference words, indexed data descrip- 
tors, and/or accidental entries. The format of 
the SIW is shown in figure II-3-4. 

If the target item is an SIW, the increment 
field of the SIW is added to the current-value 
field of the SIW, and the SIW is replaced in 
memory. If the current-value field after 
adding the increment is less than or equal to 
the final-value field, then PIR and PSR are 
advanced three syllable positions, the program 
string is continued in sequence, and an oper- 
and representing a Boolean value "true" (bit 
ON) is left in the top-of-stack. If the current- 
value field is greater than the final-value 
field, the program takes the branch by replac- 
ing PIR and PSR with the next two syllables 
from the program string. If the branch is tak- 
en, no Boolean is left in the top-of-stack. 

If the target item is an operand, the operand 
will be left in the second stack position, the 
top-of-stack will be set to zero, representing a 
Boolean value "false," and PIR and PSR will 
be advanced to the next operator. 

If the target item is other than an operand 
or SIW, the invalid-operand interrupt is set. 

COMPARE OPERATORS 

The compare operators perform the specified 
compare of two strings of data. The tru/false 
flip-flop is conditioned by the results of the 
compare. 

COMPARE CHARACTERS GREATER, DESTRUCTIVE 
(CGTD) (P)F2 

The Compare Characters Greater Destruc- 
tive operator makes a character-by-character 
comparison of two strings of data until it finds 
an unequal pair. (All comparisons are by the 
binary character position in the collating se- 
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quence.) If the characters in the B string (des- 
tination) are greater than the characters in 
the A string (source), then the true/false flip- 
flop is set to one; otherwise, the true/false flip- 
flop is set to zero. If the repeat count is less 
than or equal to zero, the true/false flip-flop is 
reset. 

The top-of-stack is an operand which 
specifies the number of characters to be com- 
pared. The second item in the stack is an oper- 
and or descriptor pointing at the source char- 
acter string against which comparisons are to 
be made. The third item in the stack is a de- 
scriptor pointing to the character string to be 
compared. If either of the data strings has the 
memory protect bit ON (bit 48=1), the seg- 
mented array interrupt is set, and the 
operation is terminated. 

COMPARE CHARACTERS GREATER, UPDATE (CGTU) 
(P)FA 

The Compare Characters Greater, Update op- 
erator performs a Compare Characters Great- 
er, Destruction operation except that the ac- 
cesses to memory continue until the repeat 
count is exhausted. At the completion of the 
operation, the source and destination pointers 
are updated. 

COMPARE CHARACTERS GREATER OR EQUAL, 
DESTRUCTIVE (CGED) (P)F1 

The Compare Characters Greater or Equal, 
Destructive operator performs a Compare 
Characters Greater, Destructive operation ex- 
cept that the true/false flip-flop is set to true 
if the destination is greater than or equal to 
the source. 

COMPARE CHARACTERS GREATER OR EQUAL, 
UPDATE (CGEU) (P)F9 

The Compare Characters Greater or Equal, 
Update operator performs a Compare Charac- 
ters Greater or Equal, Destructive operation 
except that memory accesses continue until 
the repeat count is exhausted. At the comple- 
tion of the operation, the source and destina- 
tion pointers are updated. 

COMPARE CHARACTERS EQUAL, DESTRUCTIVE 
(CEQD) (P)F4 

The Compare Characters Equal, Destructive 
operator performs a Compare Characters 
Greater, Destructive operation except that the 
true/false flip-flop is set to true if the source 
is equal to the destination. 

COMPARE CHARACTERS EQUAL, UPDATE (CEQU) 
(P)FC 

The Compare Characters Equal, Update op- 
erator performs a Compare Characters Equal, 
Destructive operation except that memory ac- 
cesses continue until the repeat count is ex- 



hausted. At the completion of the operation, 
the source and destination pointers are up- 
dated. 

COMPARE CHARACTERS LESS OR EQUAL. 
DESTRUCTIVE (CLED) (P)F3 

The Compare Characters Less or Equal, De- 
structive operator performs a Compare Char- 
acters Greater, Destructive operation except 
that the true/false flip-flop is set to true if the 
destination is less than or equal to the source. 

COMPARE CHARACTERS LESS OR EQUAL, UPDATE 
(CLEU) (P)FB 

The Compare Characters Less or Equal, Up- 
date operator performs a Compare Less or 
Equal, Destructive operation except that mem- 
ory accesses continue until the repeat count is 
exhausted. At the completion of the operation, 
the source and destination pointers are up- 
dated. 

COMPARE CHARACTERS LESS, DESTRUCTIVE (CLSD) 
(P)F0 

The Compare Characters Less, Destructive 
operator performs a Compare Characters 
Greater, Destructive operation except that the 
true/false flip-flop is set to true if the destina- 
tion is less than the source. 

COMPARE CHARACTERS LESS, UPDATE (CLSU) (P)F8 
The Compare Characters Less, Update oper- 
ator performs a Compare Characters Less, De- 
structive operation except that memory ac- 
cesses continue until the repeat count is ex- 
hausted. At the completion of the operation, 
the source and destination pointers are up- 
dated. 

COMPARE CHARACTERS NOT EQUAL, DESTRUCTIVE 
(CNED) (P)F5 

The Compare Characters Not Equal, De- 
structive operator performs a Compare Char- 
acters Greater, Destructive operation except 
that the true/false flip-flop is set to true if the 
source is not equal to the destination. 

COMPARE CHARACTERS NOT EQUAL, UPDATE 
(CNEU) (P)FD 

The Compare Characters Not Equal, Update 
operator performs a Compare Characters Not 
Equal, Destructive operation except that mem- 
ory accesses continue until the repeat count is 
exhausted. At the completion of the operation, 
the source and destination pointers are up- 
dated. 

ENTER EDIT MODE OPERATORS 

Enter edit mode operators provide the 
means for transition from primary mode oper- 
ation to edit mode operation. The edit mode 
operators in a program string are entered via 
the Execute Single Micro or Single Pointer. 
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The edit mode operators may also be in a table 
and in which case they are entered by the Ta- 
ble Enter Edit operator. (See also the descrip- 
tions under "Edit Mode Operators.") 

TABLE ENTER EDIT, DESTRUCTIVE (TEED) (P)D0 

The Table Enter Edit, Destructive operator 
is used to control edit micro instructions which 
are contained in memory as a table rather 
than as part of the normal program string 1 . 
This operator causes characters to be trans- 
ferred from the source string to the destina- 

The transfer is under control of the string of 
edit micro-operators which are located by the 
table pointer. 

The top-of -stack word (a descriptor) is the ta- 
ble pointer, the second word (a single-precision 
operand or descriptor) in the stack is the 
source pointer, and the third word in the stack 
(a descriptor) is the destination pointer. If the 
first word in the stack is not a descriptor, the 
invalid-operand interrupt is set and the 
operation is terminated. If the second item in 
the stack is a single-precision operand, it is a 
source string. If the third item in the stack is 
not a descriptor, the invalid-operand interrupt 
is set and the operation is terminated. In table 
mode, the micro-operator words can be tagged 
as single-word operands (tag-0). 

TABLE ENTER EDIT, UPDATE (TEEU) (P)D8 

The Table Enter Edit, Update operator per- 
forms a Table Enter Edit Destructive 
operation. At the completion of the operation, 
the source pointer and destination pointer are 
updated. 

EXECUTE SINGLE MICRO, DESTRUCTIVE (EXSD) 
(P)D2 

The Execute Single Micro, Destructive oper- 
ator transfers characters from the source 
string to the destination string under the con- 
trol of the single micro-operator which follows 
this operator syllable. The first item in the 
stack is a single-precision operand that defines 
the field length and is used as a micro- 
operator repeat field. The second item in the 
stack is the source pointer, the third item in 
the stack is the destination pointer. 

EXECUTE SINGLE MICRO, UPDATE (EXSU) (P)DA 

The Execute Single Micro, Update operator 
performs an Execute Single Micro, Destructive 
operation. At the completion of the operation, 
the source pointer and destination pointer are 
updated. 

EXECUTE SINGLE MICRO, SINGLE POINTER UPDATE 
(EXPU) (P)DD 

The Execute Single Micro, Single Pointer 

Update operator performs an Execute Single 



Micro, Destructive operation. At the comple- 
tion of the operation, the pointer is updated. 
The top-of -stack operand is used as a micro- 
operator repeat field. The second item in the 
stack is used to set both the source and desti- 
nation pointers. Only the destination pointer is 
updated. 

ENTER VECTOR MODE OPERATORS 

The enter vector mode operators provide the 
means of transition from primary mode to vec- 
tor mode. Either one of two operators are 
available to enter vector mode: for operations 
using instructions in only one program word, 
operator VMOS is used; for operations involv- 
ing instructions in more than one program 
word, operator VMOM is used. (See also the 
descriptions under "Vector Mode Operators.") 

Vector mode hardware provides increased ef- 
ficiency in the ordinary handling of arrays 
that frequently dominates a FORTRAN or an 
ALGOL program. For example, when process- 
ing the following FORTRAN DO loop: 

DO 10 I = 1, 100 
A(I) - B(I) + C(I) 
10 CONTINUE 

Each trip through the loop (for each value of 
I) requires a descriptor for each of the three 
arrays and the value of I with which to index 
each descriptor. This means six memory ac- 
cesses, in addition to code fetching and execu- 
tion. 



To example above (the FORTRAN DO loop) 
can be expressed in ESPOL as follows: 
DO VECTORMODE ( [ 1,1,1 ] 
A [ * ] ,B [ * ] ,C [ * ] , for 100) 

BEGIN 

A=B+C; 

INCREMENT A,B,C; 

END; 

The example has specified three increment 
values, three beginning addresses, a length (or 
number of iterations), and the operations to be 
performed on the array elements in each itera- 
tion. From this information the compiler gen- 
erates the following: 

1. Primary mode code to place the seven pa- 
rameters in the stack. 

2. The enter vector mode operator. 

3. Vector mode code to perform the 
operations on the array elements. 
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Before entering vector mode, the values to 
be stored in the IC memory registers must be 
placed in the stack. They are arranged in the 
stack in the following order (from the top-of- 
stack down): 



Pointer C 
Length (optional) 
Pointer A 
Pointer B 

Pointer C increment 
Pointer A increment 
Pointer B increment 



(descriptor) 

(operand) 

(descriptor) 

(descriptor) 

(operand) 

(operand) 

(operand) 



zero. Then vector mode is exited and normal 
operation continues with the next word of code 
in sequence. It should be noted that in the vec- 
tor mode hardware, the VMOM operator sub- 
tracts 1 from the length and then compares, 
whereas the multiple-word (VOMS) operator 
first compares the length and then subtracts. 
When the entry to vector mode is the 
(VMOM) operator, any code that follows it is 
executed under vector mode rules. The vector 
mode operators explained below are used only 
in coniunction with the VMOM operator. 



The seven parameters are inserted in the local buffer as follows: 



TBR(33)<« Pointer C [19:20] (+ Pointer C [35:16] if I = 1) 

S2LS(37)« LENGTH [19:20] (or 2 20 -l) 

-Pointer A [19:20] (+ Pointer A [39:20] if I = 1) 
-Pointer B [19:20] (+ Pointer B [39:20] if I = 1) 
-Pointer C increment [19:20] 

SIR(21)4 Pointer A increment [19:20] 

DIR(22)<t Pointer B increment [19:20] 



SBR(31)4- 
DBR(32)4- 

TIR(28)«- 



I is the indexed bit, bit 45, in the descriptor. 
(See figure 1 1-3-5.) 

The enter vector mode operator may be ter- 
minated by one of the following interrupts: 

a. INVALID OP: Pointer A, B or C not 
tagged as a data descriptor or Pointer A or B 
has bit 44=1. 

b. MEMORY PROTECT: Pointer A is read 
only (bit 43=1). 

c. PRESENCE BIT: Pointer A, B or C has 
bit 47=0. 



Length specifies the number of iterations 
through the code to be executed while in vec- 
tor mode, usually the number of elements in 
the arrays being manipulated. The presence of 
a length value in the stack is indicated by bit 
44 = 1 in Pointer C. If bit 44=0, a default length 
of 2 20 -l is stored in the length register. Bit 44 
(segmented bit) must be OFF in Pointer A and 
Pointer B. (The software ascertains that bit 44 
is OFF in Pointer C before using it to indicate 
the presence of a length value.) 



If the entry to vector mode is the single- 
word vector mode (VMOS) operator, the single 
word of code following that entry is executed 
a number of times equal to the length 
parameter. Each time the word is executed 
length is decremented by one until it becomes 



a. Vector Branch (VEBR) is a three-syllable 
operator. The two syllables following the oper- 
ator name contain the branch address. The 
Vector Branch operator examines length. If it 
is greater than zero, length is decremented by 
one, the next two program syllables containing 
the branch address are skipped, and the pro- 
gram is resumed at the following syllable. If 
the examined length is zero, vector mode is 
exited, and normal operation commences with 
the program word located by the branch ad- 
dress. 

b. Vector Exit (VXIT) operator causes the 
program to return to normal operation. 

There are 24 Vector Stack operators (with a 
common syllable format) which are used to 
move operands between the top-of-stack and 
absolute memory addresses pointed to by de- 
scriptors. Variations of this syllable provide 
the capabilities of storing or loading the top- 
of-stack with a single - or double-precision op- 
erand and choosing whether or not to incre- 
ment the pointer. If the memory address is 
protected, the following recovery procedure is 
followed: 

a. If a store operation, vector mode is termi- 
nated with a Memory Protect Interrupt. 

b. If a load operation, then: 

(1) If the length parameter was passed to 
the vector mode, vector mode is termi- 
nated with a Memory Protect Inter- 
rupt. 

(2) If no length parameter was passed to 
the vector mode, vector mode is termi- 
nated but no interrupt is set. The stack 
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INITIAL INDEX * 
IF 1 - 1 (BIT45) 


LOC = 32 
INDEX 



POINTER C 
INCREMENT 



XXX 



LOC = 23 
INDEX 



POINTER A 
INCREMENT 



XXX 



LOC = 21 
INDEX 



POINTER B 
INCREMENT 



XXX 



LOC = 22 
INDEX 



•* IF 45 THEN BASE - 33 

IF 45 THEN BASE + C [35:16] * 33 

• IF 45 THEN BASE - 31 or 32 
I = 45 AND 

SZ = THEN BASE + [39:20] - 31 or 32 

or SZ^OTHEN BASE + [35:16] ~ 31 or 32 
READ (POINTER B ONLY) MUST BE ELSE MEMORY PROTECT 



Figure 1 1 1-3-5. Vector Table 
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is then cut back as defined by the oper- 
ator that sensed the Memory Protect 
condition (refer to RA and RB below). 
The word for which a protect is sensed is not 
marked present in the stack. 

The format of the vector operator syllable is 
defined as follows: 

a. If a length is not passed when vector 
mode is entered, the format is as follows: 






LS 


f 
RAI RB 


D 


Al 


AO 


I 



where 0, the high-order bit, must be OFF (0). 

b. When a length is passed, the format is as 
follows; 



1 


1 


1 


LS 


D 


Al 


AO 


I 



where the three high-order bits must be ON 
(1). 

In either format: 

Bit Description 

D Double-precision bit. If D=0, load or store a 

single-precision operand. If D=l, load or store a 
double-precision operand. 

RA If a memory protect interrupt is sensed and no 
length is passed to the vector mode and RA=0, 
the top-of-stack word is deleted. If RA=1, the top- 
of-stack word is not deleted. 

RB Same as the RA bit except that it governs the 
action taken on the second word of the stack. 

LS Bit is OFF (0) for a top-of-stack load operator and 
ON (1) for a top-of-stack store operator. 

Al, Selects the IC memory address register. 
AO 

Al AO 









Load from Pointer A 





1 


Load from Pointer B 


1 





Load from Pointer C 



When I equals 1, the pointer used for the memory 
address is increased by its corresponding pointer 
increment following the load or store operator. 
When I equals 0, the pointer increment is 
inhibited. 



The Vector Stack operators are described 
under "Vector Mode Operators." 

Two other operators (FTCH and STOR) are 
used to load/store the top-of-stack from/to rel- 
ative memory addresses designated by an ad- 
dress couple. They are enabled only when a 
length is passed by the vector mode entry. 
(The operators FTCH and STOR are described 
under "Vector Mode Operators.") 



A memory protect interrupt occurs during 
Vector Mode if a protected word (bit 48 set) is 
sensed as a result of processing VALC, NAME, 
or stack vector operator. 

External interrupts are disabled during Vec- 
tor Mode. Exponent underflow interrupts are 
inhibited for arthmetic operators, and in lieu 
of the interrupt, an answer of zero is returned 
and the TFFF is turned ON. 

No facilities are provided for recovery from 
interrupts that occur while in vector mode. PI 
is returned with bit 19=1. 

SINGLE-WORD VECTOR MODE (VMOS) (P)EF 

The Single-Word Vector Mode operator is the 
primary mode operator used to access vector 
mode to perform on a vector those operations 
defined by one program word. VMOS extracts 
the seven parameters (described above) from 
the stack, inserts them in their IC address, 
and, after skipping up to five syllables, repea 
tedly executes the next complete word of pro- 
gram code from the program register. VMOS is 
inhibited from accessing additional program 
code, thus causing vector mode exit. 

If the descriptor in the top-of-stack has bit 
44 ON, then the second item in the stack is the 
length operand and it gives the iteration re- 
peat count; otherwise, the default repeat 
count of 1,048,575 is used. 

Each of the three descriptors (pointers) rep- 
resents a full or partial array of operands 
which will be operated on repeatedly by the 
same word of code. 

MULTIPLE-WORD VECTOR MODE (VMOM) (P)E7 

The Multiple-Word Vector Mode operator 
provides access to the vector mode operators 
for multiple program words. The VMOM 
operator performs a VMOS operation supple- 
mented by operator Vecor Branch which leads 
to additional program word loops. The special 
vector exit operator VXIT returns the pro- 
gram to normal operation. 

INDEX AND LOAD OPERATORS 

The index and load operators provide the 
means to index the top-of-stack word and the 
means to load an operand or descriptor into 
the top-of-stack. 

INDEX (INDX) (P)A6 

The two top-of-stack items are a descriptor 
(or indirect reference to a descriptor) and an 
operand. The operand is used to index the de- 
scriptor. The Index operator places the inte- 
gerized value of the second item in the stack 
into the 20-bit length/index field of the de- 
scriptor in the top-of-stack. The descriptor is 
marked indexed (i.e., bit 45 is set to "one"). 
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If the word in the top-of -stack is an operand, 
the top-of -stack operand is exchanged with the 
second-item operand. If the word in the top-of - 
stack is neither a descriptor nor an indirect 
reference word pointing to a descriptor, the in- 
valid-operand interrupt is set and the 
operation is terminated. 

If the indexing value is negative or greater 
than or equal to the length field of the de- 
scriptor, the invalid-index interrupt is set and 
the operation is terminated. 

If the descriptor represents an array which 
is segmented, the index is partitioned into two 
portions by dividing it by the proper divisor 
determined by the type of data referenced by 
the descriptor, (D.P. word-128, S.P. word-256, 4- 
bit digit-3072, 6-bit character-2048, or 8-bit 
byte-1536). The quotient is used as an index to 
the given descriptor to fetch the array-row de- 
scriptor. The remainder is used to index the 
row descriptor. 

If the double-precision bit (bit 40) in the de- 
scriptor is "one", the index value in the second 
item is doubled. The balance of the operation 
is as described in the first paragraph of this 
operator. 

INDEX AND LOAD NAME (NXLN) (P)A5 

The Index and Loa.d Name operator per- 
forms an Index operation. After the word in 
the top-of -stack is indexed, the data descriptor 
pointed to by this word is brought to the top- 
of-stack, the copy bit (bit 46) of the data de- 
scriptor is set to "one", and the top-of -stack is 
marked full. 

If the presence bit (bit 47) is OFF, the ad- 
dress of the original descriptor is placed in the 
address field of the stack copy. If the word ac- 
cessed by the indexed word in the top-of-stack 
is not a data descriptor, the invalid-operand 
interrupt is set and the operation is termi- 
nated. If the data descriptor accessed by the 
indexed word in the top-of-stack has the index 
bit (bit 45) set to "one", the invalid-operand in- 
terrupt is set and the operation is terminated. 

INDEX AND LOAD VALUE (NXLV) (P)AD 

The Index and Loa.d Value operator per- 
forms an Index operation. After the word in 
the top-of-stack is indexed, the operand 
pointed to by this descriptor is brought to the 
top-of-stack. The top-of-stack is marked full. 

If the word accessed is other than an oper- 
and the invalid-operand interrupt is set and 
the operator is terminated. 

LOAD (LOAD) (P)BD 

The Load operator places the word addressed 
by the indirect reference word or by the in- 
dexed data descriptor in the top-of-stack. 



If at the start of this operator the top-of- 
stack contains other than a data descriptor or 
an indirect reference word pointing at a data 
descriptor, the invalid- operand interrupt is set 
and the operation is terminated. 

If the word pointed at by the data descriptor 
is another data descriptor, that descriptor is 
marked as a copy (copy bit [ bit 46[ is set to 
"one") and if the presence bit (bit 47) is OFF, 
the address of the original data descriptor is 
placed in the field defined by bits 19:20 of the 
copy in the stack. 

LOAD TRANSPARENT (LODT) (V)BC 

If the top-of-stack word is a data descriptor 
or an indirect reference word, the Load Trans- 
parent operator performs a Load operation; 
otherwise, the word addressed by the 20 least- 
significant bits of the top-of-stack word is 
loaded to the top-of-stack. Copy-bit action does 
not occur. 

INPUT CONVERT OPERATORS 

The input convert operators convert the var- 
ious character sets (digit, BLC, EBCDIC, or 
ASCII) to operands for arithmetic operations. 

INPUT CONVERT, DESTRUCTIVE (ICVD) (P)CA 

The Input Convert, Destructive operator con- 
verts 4-bit digit, or 6-bit BCL, or 8-bit EBCDIC 
(or ASCII) to an operand for internal arithme- 
tic operations. 

The first item in the stack is an operand 
that is integerized to form the repeat field. 
The second item in the stack is a descriptor 
used as a source pointer. 

The specified number of characters are 
transferred from the source string to the top- 
of-stack. Only the numeric portion of the char- 
acter is transferred. The transferred string is 
converted to a double-precision operand if the 
length is greater than 12. If a double-precision 
operand is produced, the true/false flip-flop is 
set to false; otherwise, it is set to true. The 
sign bit of the operand is set negative if the 
zone of the last character transferred is 10 2 
(for six-bit characters) or 1101 2 (for eight-bi 
characters). At the completion of the operator 
the second item in the stack is marked full. 
The tag field is set to indicate a single - or 
double-precision operand. 

INPUT, CONVERT, UPDATE (ICVU) (P)CB 

The Input Convert, Update operator per- 
forms an Input Convert, Destructive 
operation. At the completion of the operation, 
the source pointer is updated. 
LITERAL CALL OPERATORS 

The literal call operators place defined-value 
operands in the top-of-stack. 
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LIT CALL ZERO (ZERO) (P)BO 

The Lit Call Zero operator places in the top- 
of-stack a single-precision operand with a val- 
ue of zero. 

LIT CALL ONE (ONE) (P)B1 

The Lit Call One operator places in the top- 
of-stack a single-precision operand with a val- 
ue of one. 

LIT CALL 8 BITS (LT8) (P)B2 

The Lit Call 8 Bits operator places in the 
top-of -stack a single-precision operand equal in 
value to the second syllable of this operator. 

LIT CALL 16 BITS (LT16) (P)B3 

The Lit Call 16 Bits operator places in the 
top-of -stack a single-precision operand equal in 
value to the second and third syllables of this 
operator. 

LIT CALL 48 BITS (LT48) (P)BE 

The Lit Call 48 Bits operator places in the 
top-of -stack a single-precision operand equal in 
value to the next program word. 

NOTE 
Since the literal is synchronized by 
word, this operator can be 7-12 syl- 
lables long. Any unused syllables 
are filled in with the invalid 
operator code. 

MAKE PROGRAM CONTROL WORD (MPCW) (P)BF 

The Make Program Control Word operator 
performs a Lit Call 48 Bits operation except 
that the tag field is set to 111 to indicate a 
program control word and the stack number 
field of the PCW is inserted from the stack 
number register. 

LOGICAL OPERATORS 

Logical operators operate on the two top-of - 
stack operands bit for bit from bit 47 thru bit 
to obtain logical values (48 logical values for 
single-precision operands and 96 for double- 
precision operands) which are left as the top- 
of-stack operand. If only one of the operands 
associated with LAND, LOR, LNOT, or LEQV 
is a double-precision operand, then the other 
operand will be extended with zeros. Logical 
operators may be used to operate on logical, 
string, or numeric operands. 

LOGICAL AND (LAND) (P)90 

The Logical And operator logically AND's 
each bit (except tag bits) of the two top-of- 
stack operands leaving the result in the top-of - 
stack. Each bit of the top-of-stack operand is 
set to one where a one appears in the corre- 
sponding bit positions of the two top-of-stack 
operands; the other information bits in the 



top-of-stack operand are set to zero. The tag of 
the second operand is undisturbed except for a 
double-precision operand in the top-of-stack, in 
which case the second operand is made double 
precision and the tag field is changed accord- 
ingly. AND is defined as follows: 



Operand A 


Operand B 


A AND B 






1 
1 



1 

1 






1 



NOTE 
The tag field is set equal to the 
second item in the stack. 

LOGICAL OR (LOR) (P)91 

The Logical Or operator logically OR's each 
bit (except tag bits) of the two top-of-stack op- 
erands leaving the result in the top-of-stack. 
OR is defined as follows: 



Operand A 


Operand B 


A OR B 














1 


1 


1 





1 


1 


1 


1 



NOTE 
The tag field is set equal to the 
second item in the stack. 

LOGICAL NEGATE (LNOT) (P)92 

The Logical Negate operator complements 
each bit position (except tag bits) of the top-of- 
stack operand. 

LOGICAL EQUIVALENCE (LEQV) (P)93 

The Logical Equivalence operator compares 
the corresponding bits of the two items in the 
top-of-stack (except the tag bits). The two 
items are replaced by a single item with a tag 
field equal to the tag field of the second item 
in the stack and by a one in each bit position 
where the corresponding bits of the two top-of- 
stack items were equal. 

PACK OPERATORS 

PACK, DESTRUCTIVE (PACD) (P)D1 

The Pack, Destructive operator packs data 
(as addressed by the source pointer) right-jus- 
tified into the top-of-stack in 4-bit (digit) for- 
mat. 

The top-of-stack operand defines the length/ 
repeat field (in digits) to be packed. The source 
pointer is the second item in the stack. The 
specified number of digits are transferred 
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from the source to the top-of-stack (.dropping 
the zones when required). If the digit length 
transferred is less than 13 the tag field in the 
top-of-stack is set to a single-precision oper- 
and; otherwise, the tag field is set to a double- 
precision operand. 

If the length is not less than 25 an invalid- 
operand interrupt is set and the operation is 
terminated. If the source data has the memory 
protect bit (bit 48) set to "one," the segmented- 
array interrupt is set and the operation is ter- 
minated. 

If the sign of the source data is negative, 
the true/false flip-flop is set to "one;" other- 
wise, the flip-flop is reset. Sign conventions 
are as follows: 



Data Bit 
Format 

4-bit 
6-bit 
8-bit 

8-bit 



Sign Location 



Most significant digit 
Least significant character 
Least significant byte 

Least significant byte 



Neg. Sign 

Zone Bit 
Config. 

1101 

10 

1101 

(EBCDIC) 

1111 (ASCII) 



PACK, UPDATE (PACU) (P)I>9 

The Pack, Update operator performs a Pack, 
Destructive operation. At the completion of 
the operation, the source pointer is updated. 

RELATIONAL OPERATORS 

The relational operators perform algebraic 
comparisons on the two top-of-stack operands., 
The operands are removed from the stack and 
the result of the comparison is a logical oper- 
and which is placed in the top-of-stack. The re- 
sult is a single-precision operand with the 
least significant bit set to one if the relation is 
true or a single-precision operand with all in- 
formation bits set to zero if the relation is 
false. 

GREATER THAN (GRTR) (P)8A 

If the second operand in the stack is greater- 
than the top-of-stack operand, the Greater 
Than operator replaces the two operands with 
a single-precision operand which has the least- 
significant bit set to one. 

If the second operand in the stack is not 
greater than the top-of-stack operand, the two 
operands are replaced with a single-precision 
operand which has all information bits set to 
zero. 

GREATER THAN OR EQUAL (GREQ) (P)89 

If the second operand in the stack is greater 
than or equal to the top-of-stack operand, the 
Greater Than or Equal operator replaces the 
two operands with a single-precision operand 
which has the least-significant bit set to one. 



If the second operand in the stack is not great- 
er than or equal to the top-of-stack operand, 
the two operands are replaced with a single- 
precision operand which has all information 
bits set to zero. 

EQUAL (EQUL) (P)8C 

If the second operand in the stack is algebra- 
ically equal to the top-of-stack operand, the 
Equal operator replaces the two operands with 
a single-precision operand which has the least- 
significant bit set to "one". If the second oper- 
and in the stack is not equal to the top-of- 
stack operand, the two operands are replaced 
with a single-precision operand which has all 
information bits set to zero. 

LESS THAN OR EQUAL (LSEQ) (P)8B 

If the second operand in the stack is less 
than or equal to the top-of-stack operand, the 
Less Than or Equal operator replaces the two 
operands with a single-precision operand 
which has the least significant bit set the 
"one". If the second operand in the stack is 
not less than or equal to the top-of-stack oper- 
and, the two operands are replaced with a sin- 
gle-precision operand which has all informa- 
tion bits set to zero. 



LESS THAN' (LESS) (P)88 

If the second operand in the stack is less 
than the top-of-stack operand, the Less Than 
operator replaces the two operands with a sin- 
gle-precision operand which has the least-sig- 
nificant bit set to "one". If the second operand 
in the stack is not less than the top-of-stack 
operand, the two operands are replaced with a 
single-precision operand which has all infor- 
mation bits set to zero. 

NOT EQUAL (NEQL) (P)8D 

If the second operand in the stack is not 
equal to the top-of-stack operand, the Not 
Equal operator replaces the two operands with 
a single-precision operand with the least sig- 
nificant bit set to "one". If the second operand 
in the stack is equal to the top-of-stack oper- 
and, the two operands are replaced with a sin- 
gle-precision operand which has all informa- 
tion bits set to zero. 

LOGICAL EQUAL (SAME) (P)94 

The Logical Equal operator compares all bits 
(including: tag bits) of the two items (operands, 
control words, descriptors, etc.) in the top-of- 
stack. If all bits are equal, a single-precision 
operand (with the least significant bit set to 
one and all other information bits set to zero) 
is stored in the top-of-stack; otherwise, a sin- 
gle-precision operand with all information bits 
set to zero is stored in the top-of-stack. 
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SCALE OPERATORS 

Some higher level languages such as COBOL 
and PL-I require integer arithmetic. The 
Scale-Left operators provide a means of align- 
ing the decimal points prior to performing 
arithmetic operations. The Scale-Right 
operators provide a means of converting bina- 
ry arithmetic to decimal arithmetic. 

SCALE LEFT (SCLF) (P)C0 

The Scale Left operator shifts the operand in 
the top-of-stack for decimal point alignment. 
The operand in the top-of-stack is first con- 
verted to an integer and then multiplied by 10 
raised to the power specified by the scale fac- 
tor. The scale factor is obtained from the sec- 
ond syllable (i.e., the program syllable fol- 
lowing the operator syllable). 

If scaling of a single-precision operand 
would result in overflow, the single-precision 
operand is converted to a double-precision in- 
teger. For the Scale operators, a double-preci- 
sion integer is defined as a double-precision 
operand with an exponent equal to 13 (octal). 
If scaling of the operand results in an expo- 
nent greater than 13 (double-precision oper- 
and), the overflow flip-flop is set to "one". 

DYNAMIC SCALE LEFT (DSLF) (P)C1 

The Dynamic Scale Left operator performs a 
Scale Left operation except that the scale fac- 
tor is obtained from the top-of-stack operand 
and the operand to be scaled is the second op- 
erand in the stack. The operand in the top-of- 
stack is converted to an integer before scaling 
takes place. 

SCALE RIGHT SAVE (SCRS) (P)C4 

The Scale Right Save operator shifts the top- 
of-stack operand to the right for conversion 
from a binary to a decimal numbering system. 
The operand in the top-of-stack is converted to 
an integer and divided by 10 raised to the 
power specified by the scale factor. The scale 
factor is obtained from the second syllable. If 
the scale factor is greater than 12, the invalid- 
operand interrupt is set and the operation is 
terminated. 

The quotient resulting from the division is 
left in the top-of-stack. The second operand in 
the stack is the remainder which is converted 
to decimal (4-bit digits) and left justified. 

DYNAMIC SCALE RIGHT SAVE (DSRS) (P)C5 

The Dynamic Scale Right Save operator per- 
forms a Scale Right Save operation except 
that the scale factor is obtained from the top- 
of-stack operand and the operand to be scaled 
is the second item in the stack. The top-of- 
stack operand is converted to an integer be- 
fore scaling takes place. 



SCALE RIGHT TRUNCATE (SCRT) (P)C2 

The Scale Right Truncate operator performs 
a Scale Right Save operation except that the 
remainder resulting from the division is de- 
leted from the stack. 

DYNAMIC SCALE RIGHT TRUNCATE (DSRT) (P)C3 

The Dynamic Scale Right Truncate operator 
performs a Scale Right Truncate operation ex- 
cept that the scale factor is obtained from the 
top-of-stack operand and the operand to be 
scaled is the second operand in the stack. 

SCALE RIGHT ROUNDED (SCRR) (P)C8 

The Scale Right Rounded operator performs 
a Scale Right Save operation except that the 
remainder resulting from the division is de- 
leted from the stack. If the most significant 
digit of the remainder is greater than or equal 
to five the quotient from the division is 
rounded by adding "one" to it. 

DYNAMIC SCALE RIGHT ROUNDED (DSRR) (P)C9 

The Dynamic Scale Right Rounded operator 
performs a Scale Right Rounded operation ex- 
cept that the scale factor is obtained from the 
top-of-stack operand and the operand to be 
scaled is the second operand in the stack. 

SCALE RIGHT FINAL (SCRF) (P)C6 

The Scale Right Final operator performs a 
Scale Right Save operation except that the 
quotient is deleted from the stack and the sign 
of the quotient is copied into the external sign 
flip-flop. If the quotient was not equal to zero 
at the conclusion of the operation, the over- 
flow flip-flop is set. 

DYNAMIC SCALE RIGHT FINAL (DSRF) (P)C7 

The Dynamic Scale Right Final operator per- 
forms a Scale Right Final operation except 
that the scale factor is obtained from the top- 
of-stack operand and the operand to be scaled 
is the second item in the stack. 

STACK OPERATORS 

The stack operators are used to adjust the 
relative positions of the top items in the stack 
and to copy or delete the top of stack item. 

EXCHANGE (EXCH) (P)B6 

The Exchange operator causes the two top- 
of-stack items to be exchanged. 

ROTATE STACK DOWN (RSDN) (V)B7 

The Rotate Stack Down operator rotates the 
three top-of-stack words as follows: 



Before Rotation 

Word 1 
Word 2 
Word 3 



After Rotation 

Word 2 
Word 3 
Word 1 
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ROTATE STACK UP (RSUP) (V)B6 

The Rotate Stack Up operator rotates the 
three top-of -stack words as follows: 



Before Rotation 

Word 1 
Word 2 
Word 3 



After Rotation 

Word 3 
Word 1 
Word 2 



DUPLICATE TOP-OF-STACK (DUPL) (P)B7 

The Duplicate Top-of-Stack operator dupli- 
cates the item in the top-of-stack. 

DELETE TOP-OF-STACK (DLET) (P)B5 

The Delete Top-of-Sta.ck operator deletes the 
top-of-stack item. 

PUSH DOWN STACK REGISTERS (PUSH) (P)B4 

The Push Down Stack Registers operator 
pushes down the top-of-stack items and stack 
buffer contents into memory. 

STORE DESTRUCTIVE (STOD) (P)B8 

The Store Destructive operator stores the 
second item in the stack into memory. The ad- 
dress into which the item is to be stored is in- 
dicated by an indirect reference word or in- 
dexed data descriptor in the top-of-stack. If 
the top-of-stack item is an operand, the two 
top-of-stack items are exchanged so that the 
address item is in the top-of-stack and the 
item to be stored is in the second position. Af- 
ter the item is stored, both the item and its ad- 
dress are deleted from the stack. 

If the word addressed by the indirect refer- 
ence word is another indirect reference word 
or indexed data descriptor, or the word ad- 
dressed by the data descriptor is another in- 
dexed data descriptor, the store operation will 
not occur to that location, but will be retried 
using the address indicated by that word. This 
chaining of address items will continue until a 
"target" location is reached; however, once a 
data descriptor has been encountered, an indi- 
rect reference word or PCW is not allowed, and 
once a stuffed indirect reference word has 
been encountered, a normal IRW is not al- 
lowed. Either of these conditions will cause an 
invalid-operand interrupt. 

If the word addressed by the indirect refer- 
ence word is a program control word, acciden- 
tal procedure entry occurs. The spontaneously 
generated RCW causes STOD to be reexecuted 
upon return from the procedure. 

If a data descriptor used as an address item 
has the read-only bit (bit 43) ON, or if the ad- 
dressed word has the memory protect bit (bit 
48) ON and is not a data descriptor, IRW, or 
PCW, the memory-protect interrupt is set and 
the operation is terminated. 



If the presence bit in the data descriptor is 
zero, the presence-bit interrupt is set. After 
the data has been made present, the operation 
is restarted. 

STORE NON-DESTRUCTIVE (STON) (P)B9 

The Store Non-Destructive operator per- 
forms a Store Destructive operation, except 
that only the address item is deleted from the 
stack. The item which was stored is left in the 
top-of-stack. 

OVERWRITE DESTRUCTIVE (OVRD) (P)BA 

The Overwrite Destructive operator per- 
forms a Store Destructive operation, except 
that the addressed location will be overwritten 
regardless of its contents. Chaining of address 
items, memory protection checks, or accidental 
procedure entry do not occur. 

OVERWRITE NON-DESTRUCTIVE (OVRN) (P)BB 

The Overwrite Non-Destructive operator per- 
forms a Store Non-Destructive operation, ex- 
cept that the addressed location will be over- 
written regardless of its contents. Chaining of 
address items, memory protection checks, or 
accidental procedure entry do not occur. 

READ WITH LOCK (RDLK) (V)BA 

The Read With Lock operator is a variant of 
the Overwrite Non-Destructive operator. The 
word in the top-of-stack and the specified word 
in memory are interchanged after all local 

STRING OPERATORS 

The string operators are used for transfer- 
ring, comparing, scanning, and translating 
strings of data. In addition, a set of micro-op- 
erators provide a means of formatting data for 
input/output. 

The string operators use a repeat value and 
source and destination pointers which are lo- 
cated in the stack. For most string operators, 
the repeat value range is from to 2 20 -l. If 
the repeat value is < 0, the string operator 
checks for valid inputs and terminates. If the 
string operator is an update type operator, the 
normal updated descriptors are produced. 

The source for the string operator can either 
be a pointer into an array or a single or double 
precision operand. If the source is an operand, 
the source character size is determined by ei- 
ther the string operator or the destination 
character size. The first source character to be 
used by the string operator is the left most 
character in the most significant word of the 
operand. 
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As the string operator acts upon each char- 
acter in the operand, the operand is rotated 
left by one character so that the next charac- 
ter to be used is always the left most charac- 
ter in the rotated source operand. For update 
type string operators, the operand is placed 
back into the stack in its rotated form. The 
source and destination pointers can be: 



pointer. If the number of bytes exceeds one 
word (6 bytes or 48 bits), the tag of the result 
is set to double precision. If the number of bits 
is greater than 96, an invalid operand inter- 
rupt is set and the operation is terminated. If 
the source data has the memory-protect bit 
(bit 48) set to "one", the segmented-array in- 
terrupt is set and the operation is terminated. 



a. An unindexed data descriptor. 

b. An indexed data descriptor. 

c. An unindexed string descriptor. 

d. An indexed string descriptor. 

When one descriptor (source or destination) 
is a data descriptor and the other is a string 
descriptor, the data descriptor is converted to 
a string descriptor of the same type. 



STRING TRANSFER OPERATORS 

String transfer operators give the system 
the ability to transfer characters or words 
from one location in memory to another loca- 
tion in memory. The source and destination 
pointers are set from string descriptors in the 
stack. 



If both descriptors are data descriptors or 
there is only one descriptor and it is a data de- 
scriptor, then the conversion is made to 8-bit 
character string descriptors. Note that the in- 
dex field used by the string operators is the 
same as that found in the original descriptors. 



If string descriptors, except for the translate 
and transfer word operators, contain different 
character sizes, the invalid-operand interrupt 
is caused. 

If string operators contain an update vari- 
ant, the indexed string descriptors pointing to 
the next character in the array to be used are 
left in the stack. 

STRING ISOLATE (SISO) (P)D5 

The String Isolate operator transfers from 
the source string to the top-of -stack the num- 
ber of bytes specified by the repeat field. This 
string is right-justified and filled with leading 
zeros. 

At the start of the operation, the top-of- 
stack operand specifies the length of the byte 
string and the second item in the stack is an 
operand or a descriptor used as the source 



TRANSFER WORDS, DESTRUCTIVE (TWSD) (P)D3 

The Transfer Words, Destructive operator 
transfers the number of words specified by the 
top-of -stack operand and from the source 
string to the destination string. The first oper- 
and is integerized and is used as the count or 
repeat field. The second item in the stack (a 
string descriptor or operand) is the source 
pointer; i.e., it points at the source string. The 
third item in the stack (a string descriptor) is 
the destination pointer which is used to pro- 
vide the address of the destination string. The 
number of words specified by the repeat field 
are transferred from the source to the destina- 
tion. If the memory protect bit is ON during 
execution of the Transfer Words operator, 
then the segmented-array interrupt is set and 
the operation is terminated. 



TRANSFER WORDS, UPDATE (TWSU) (P)DB 

The Transfer Words, Update operator per- 
forms a Transfer Words, Destructive 
operation. At the completion of the operation 
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the source and destination pointers are up- 
dated to point to the memory location where 
the transfer ended. IP either pointer was a 
data descriptor, then an indexed data descrip- 
tor is updated. 

TRANSFER WORDS, OVERWRITE DESTRUCTIVE 
(TWOD) (P)D4 

The Transfer Words, Overwrite Destructive 
operator performs a Transfer Words, Destruc- 
tive operation bypassing the memory-protec- 
tion checks. 

TRANSFER WORDS, OVERWRITE UPDATE (TWOU) 
(P)DC 

The Transfer Words, Overwrite Update oper- 
ator performs a Transfer Words, Update oper- 
ation bypassing the memory-protection checks. 

TRANSFER WHILE GREATER, DESTRUCTIVE (TGTD) 

(P)E2 

The Transfer While Greater, Destructive op- 
erator transfers the number of characters 
specified by the second operand (bits 19:20) in 
the stack or while the source character is 
greater than a delimiter. The top-of-stack op- 
erand is the delimiter. The third item in the 
stack is the source pointer, and the fourth 
item is the destination pointer. 

If the second item in the stack is a descrip- 
tor, it is used as a source pointer. This means 
that no repeat field was given and the default 
field length is 1,048,575. 

If either the source or destination word has 
the memory protect bit ON (bit 48 = 1), the 
segmented-array interrupt is set and the oper- 
ation is terminated. 

All comparisons are binary (EBCDIC collat- 
ing sequence). When the source pointer is an 
operand, it must be a single-precision operand 
or an invalid-operand interrupt is set and the 
operation is terminated. The source character 
is compared with the delimiter. If the 
comparison is true, the true/false flip-flop is 
set to "one"; if the comparison fails, the true/ 
false flip-flop is set to zero. 

TRANSFER WHILE GREATER, UPDATE (TGTU) (P)EA 

The Transfer While Greater, Update 
operator performs a Transfer While Greater, 
Destructive operation. At the completion of 
the operation, the source and destination 
pointers are updated to point at the next char- 
acter in the source and destination strings, re- 
spectively. At the completion of the operation, 
a count of the number of characters not trans- 
ferred is placed on the top-of-stack. If all the 
characters specified by the length field are 
transferred, the true/false flip-flop is set to 
true; otherwise, the true/false flip-flop is set to 
false. 



If the operation is terminated because the 
relationship is not met, the source pointer 
points to the character which stopped the 
transfer. 

TRANSFER WHILE GREATER OR EQUAL, 
DESTRUCTIVE (TGED) (P)E1 

The Transfer While Greater or Equal 
operator performs a Transfer While Greater, 
Destructive operation while the source charac- 
ter is greater than or equal to the delimiter. 

TRANSFER WHILE GREATER OR EQUAL, UPDATE 
(TGEU) (P)E9 

The Transfer While Greater or Equal, Up- 
date operator performs a Transfer While 
Greater Than or Equal operation. At the com- 
pletion of the operation, the source and desti- 
nation pointers and the count are updated. 

TRANSFER WHILE EQUAL, DESTRUCTIVE (TEQD) 

(P)E4 

The Transfer While Equal, Destructive oper- 
ator performs a Transfer While Greater or 
Equal, Destructive operation while the source 
character is equal to the delimiter. 

TRANSFER WHILE EQUAL, UPDATE (TEQU) (P)EC 

The Transfer While Equal, Update operator 
performs a Transfer While Equal, Destructive 
operation. At the completion of the operation, 
the source and destination pointers and the 
count are updated. 

TRANSFER WHILE LESS OR EQUAL, DESTRUCTIVE 
(TLED) (P)E3 

The Transfer While Less or Equal, Destruc- 
tive operator performs a Transfer While 
Greater or Equal, Destructive operation while 
the source character is less than or equal to 
the delimiter. 

TRANSFER WHILE LESS OR EQUAL, UPDATE (TLEU) 
(P)EB 

The Transfer While Less or Equal, Update 
operator performs a Transfer While Less or 
Equal, Destructive operation. At the comple- 
tion of the operation, the source and destina- 
tion pointers and the count are updated. 

TRANSFER WHILE LESS, DESTRUCTIVE (TLSD) (P)E0 
The Transfer While Less, Destructive 
operator performs a Transfer While Less or 
Equal, Destructive operation while the source 
character is less than the delimiter. 

TRANSFER WHILE LESS, UPDATE (TLSU) (P)E8 

The Transfer While Less, Update operator 
performs a Transfer While Less, Destructive 
operation. At the completion of the operation, 
the source and destination pointers and the 
count are updated. 
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TRANSFER WHILE NOT EQUAL, DESTRUCTIVE 
(TNED) (P)E5 

The Transfer While Not Equal, Destructive 
operator performs a Transfer While Greater or 
Equal, Destructive operation while the source 
character is not equal to the delimiter. 

TRANSFER WHILE NOT EQUAL, UPDATE (TNEU) 
(P)ED 

The Transfer While Not Equal, Update oper- 
ator performs a Transfer While Not Equal De- 
structive operation. At the completion of the 
operation, the source and destination pointers 
and the count are updated. 

TRANSFER WHILE TRUE, DESTRUCTIVE (TWTD) 
(V)D3 

The Transfer While True, Destructive 
operator transfers characters from the source 
string to the destination string for the number 
of characters specified by the length operand 
while the stated relationship is met. If the re- 
lationship is not met the transfer is termi- 
nated at that point. The relationship is deter- 
mined by using the source character to index 
a bit in the table. If the bit indexed is a "one" 
the relationship is true. An all zero's character 
indexes to the most significant bit of the table. 

The operator uses the top four words in the 
stack as follows: The top-of -stack word is a ta- 
ble pointer to specific addresses in the table; 
the second word in the stack provides the 
length of the string to be transferred or, if it 
is a descriptor, it is used as a source pointer 
since no repeat field was given and the default 
field length is set at 1,048,575; the third word 
in the stack is an operand or a descriptor 
which gives the address of the source string or 
is a single-precision operand which is the 
source string; the fourth word in the stack is 
a descriptor pointing at the destination string. 

The table is indexed as follows to obtain the 
decision bit: The source character is expanded 
to eight bits, if necessary, by appending two or 
four leading-zero bits. The three high-order 
bits of the source character select a word from 
the table, indexing the table pointer. The re- 
maining five bits of the expanded source char- 
acter select a word from the table, indexing 
the table pointer. The remaining five bits of 
the expanded source character select (by their 
value) a bit from this word. 

At the completion of the operation, a count 
of the number of characters not transferred is 
placed on the top of stack. 

If all the characters specified by the length 
field are transferred, the true/false flip-flop is 
set to true; otherwise, the true/false flip-flop is 
set to false. 



The table format is as follows: 



Source Size 

4 
6 
8 



Table Length 

1 word 

2 words 
8 words 



Bits/Word 

(31:16) 
(31:32) 
(31:32) 



TRANSFER WHILE TRUE, UPDATE (TWTU) (V)DB 

The Transfer While True, Update operator 
performs a Transfer While True, Destructive 
operation. At the completion of the operation, 
the source destination pointers and the count 
are updated. If all the characters specified by 
the length field are transferred, the true/false 
flip-flop is set to "one" (true); otherwise it is 
set to zero. 

TRANSFER WHILE FALSE, DESTRUCTIVE (TWFD) 
(V)D2 

The Transfer While False, Destructive 
operator performs the Transfer While True op- 
eration except that the relationship is true if 
the bit found by indexing into the table is a 
zero. 

TRANSFER WHILE FALSE, UPDATE (TWFU) (V)DA 

The Transfer While False, Update operator 
performs a Transfer While False, Destructive 
operation. At the completion of the operation, 
the source and destination pointers and the 
count are updated. 

TRANSFER UNCONDITIONAL, DESTRUCTIVE (TUND) 
(P)E6 

The Transfer Unconditional, Destructive op- 
erator transfers from the source to the desti- 
nation the number of characters specified by 
the top-of-stack operand. If the top-of-stack 
item is a descriptor, it is used as a source 
pointer. Since no repeat field was given, the 
field length is set by default at 1,048,575. The 
second item in the stack is the destination 
pointer. If all characters specified by the 
length field are transferred, the true/false 
flip-flop is set to "one" (true) by this operand; 
otherwise, the flip-flop is set to zero (false). 

TRANSFER UNCONDITIONAL, UPDATE (TUNU) (P)EE 

The Transfer Unconditional, Update 
operator performs a Transfer Unconditional, 
Destructive operation. At the completion of 
the operation, the source and destination 
pointers are updated. 

SUBROUTINE OPERATORS 

Subroutine operators are those operators 
which can move the program operation across 
machine architecture such as from stack to 
stack, or from subroutine to subroutine, etc. 
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Any subroutine operator which can "chain" 
indirect reference words (IRW's) or stuffed in- 
direct reference words (SIRW's) can obtain ac- 
cidental procedure entry if a program control 
word (PCW) is pointed to by the IRW or SIRW 
last in the chain. 

MARK STACK (MKST) (P)AE 

The Mark Stack operator inserts a mark into 
the stack which is to be subsequently used by 
an Enter operator. The mark is placed in the 
top-of-stack in the form of a mark stack con- 
trol word. The F register is set to the location 
of the MSCW. 

The Mark Stack operator is normally used 
when an entry to a procedure is anticipated. 
The normal sequence of events to enter a pro- 
cedure is (1) mark the stack; (2) insert an indi- 
rect reference to a program control word; (3) 
insert parameters, if any are to be passed to 
the procedure; and then (4) execute an Enter 
operator, which will in turn, cause an entry 
into the program segment located by the pro- 
gram control word. 

INSERT MARK STACK (IMKS) (P)CF 

The Insert Mark Sta.ck operator inserts a 
mark stack control word in the current stack 
below the two top-of-stack items. 

NAME CALL (NAMC) (P)40 THRU (P)7F 

Name Call builds an indirect reference word 
in the top-of-stack. The six low-order bits of 
the first syllable and the eight bits of the sec- 
ond syllable form a 14-bit address couple. This 
address couple is placed in the top-of-stack 
with the tag field set to 001. 

In the B 7700, if the Name Call is followed 
by a ENTR, INDX, NXLN, NXLV, STOD, 
STON, OVRD, OVRN, DBUN, LOAD, or LODT 
operator, the IRW is not placed in the stack. 
Instead, the referenced memory address is cal- 
culated and, if appropriate, the memory access 
is initiated by the program control unit. The 
following operator is sent to the execution unit 
along with an indication that the operator has 
been started. Since thc^ address computation 
and, in some cases, the memory fetch, is com- 
plete by the time the operator reaches the 
execution unit, a considerable time savings is 
realized. 

VALUE CALL (VALC) (P)00 THRU (P)3F 

Value Call is a two-syllable instruction that 
brings an operand from memory into the top- 
of-stack. A concatenation of the two Value Call 
syllable gives a 14-bit address couple. If the 
referenced memory location contains an indi- 
rect reference word or a data descriptor, addi- 
tional memory accesses are made until the 
"target" operand is located. The operand is 



then placed in the top-of-stack. The operand 
may be either single-precision or double-preci- 
sion, causing either one or two words to be 
loaded into the top-of-stack. (Figures 1 1 1-3-6 is 
simplified flow charts of the Value Call 
operator.) 

If the word accessed is an indexed data de- 
scriptor, the word addressed by the data de- 
scriptor is brought to the top-of-stack. If the 
word accessed is a non-indexed word data de- 
scriptor, the descriptor is indexed using the 
second word in the stack as the index value, 
and the word addressed by the non-indexed 
data descriptor is brought to the top-of-stack. 
If the double-precision bit (bit 40) in the data 
descriptor is set, the second half of the double- 
precision operand is placed in the second half 
of the top-of-stack location. 

If the presence bit in the data descriptor is 
zero, the presence-bit interrupt is set. After 
the data has been made present, the operation 
is restarted. 

If a data descriptor does not address an op- 
erand, step index word, or a word descriptor or 
indexed string descriptor, an invalid-operand 
interrupt is set and the operation is termi- 
nated. 

If the word accessed by the Value Call is an 
indirect reference word (IRW), the word ad- 
dressed by the IRW is brought to the top-of- 
stack. 

If the word accessed is a program control 
word (PCW), an accidental entry into the sub- 
routine addressed by the PCW is initiated. A 
mark stack control word and return control 
word are placed in the stack and an entry is 
made into the subprogram. Upon completion of 
the subprogram, a return operation will re-en- 
ter the Value Call operator flow. 

If the target operand is a step index word 
(tag = 4) instead of an operand, the current- 
value field (bits 15:16) of the SIW will be 
placed in the top-of-stack with the tag set to 
zero. 

The "chaining" of memory accesses contin- 
ues until a target operand is reached; how- 
ever, once a data descriptor has been encoun- 
tered, an indirect reference word or PCW is 
not allowed, and once a stuffed indirect refer- 
ence word has been encountered, a normal 
IRW is not allowed. Either of these conditions 
will cause an invalid-operand interrupt. 

EVALUATE DESCRIPTOR (EVAL) (P)AC 

The Evaluate Descriptor operator loads into 
the top of stack a data descriptor or an indi- 
rect reference word which points to the refer- 
enced operand. This operand may be refer- 
enced through a chain of indirect reference 
words or descriptors. (Figure III-3-7 is a sim- 
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Figure III-3-6. Flow Chart of Value Call Operator (Sheet 1 of 2) 
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Figure III-3-6. Flow Chart of Value Call Operator (Sheet 2 of 2) 
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plified flow chart of the Evaluate Descriptor 
operator.) 

A descriptor is left in the stack if the oper- 
and was referenced by a descriptor. If only in- 
direct reference words are used, multiple 
memory accesses are made until the operand 
is located. A stuffed indirect reference word 
pointing to the operand is left in the stack. 

An invalid-operator interrupt is set and the 
operation is terminated if the top-of-stack 
word is not a descriptor or an indirect refer- 
ence word at the start of the Evaluate 
operator. 

ENTER (ENTR) (P)AB 

The Enter operator causes an entry into a 
procedure from a calling procedure. (The se- 
quence of events to enter a procedure is: (1) 
mark the stack; (2) insert an indirect reference 
to a program control word; (3) insert 
parameter(s), if any are to be passed to the 
procedure; and, (4) execute an Enter operator.) 
The Enter operator causes entry into the pro- 
gram segment located by the program control 
word. A return control word is stored at stack 
location F+l. (Figure III-3-8 is a flow chart of 
the Enter operator.) 

EXIT (EXIT) (P)A3 

The EXIT operator causes a called procedure 
to return to a calling procedure and is used 
when the called procedure is not required to 
return a result. The Exit operator returns all 
control registers to the position they were in 
prior to the calling procedure, saves the bot- 
tom of stack register (BOSR), and cuts back 
the stack. (Figure III-3-9 is a flow chart of the 
Exit operator.) 

RETURN (RETN) (P)A7 

The Return operator causes a called proce- 
dure to return to a calling procedure (as in 
EXIT) but is used when the called procedure is 
required to return a result. An operand or 
name in the top-of-stack is returned to the 
calling procedure. If a name is returned and 
the V bit (bit 19) in the MSCW is ON, the name 
is evaluated to yield an operand as in VALC 
(since the V-bit indicates that the RETN is to 
VALC which caused accidental entry). (See fig- 
ure III-3-9.) 

TRANSFER OPERATORS 

The transfer operators transfer any field of 
bits from one word in the stack to any field of 
another word in the stack. 

NOTE 
For all transfer operators the val- 
ues specified in the stack must be 
non-negative. 



FIELD TRANSFER (FLTR) (P)98 

The Field Transfer operator uses the three 
syllables following it to establish the pointers 
used in the field transfer. Stack adjustment 
takes place so that the two top-of-stack loca- 
tions are full. The contents of the field in the 
top-of-stack, starting at the bit position ad- 
dressed by the third syllable of FLTR, is 
transferred into a field of corresponding 
length in the second location in the stack. The 
field in the second location in the stack starts 
at the bit position indicated by the second syl- 
lable of FLTR and proceeds toward the low-or- 
der-bit positions. When the number of bits 
specified by the fourth syllable of FLTR has 
been transferred the top-of-stack word and the 
operation is complete. 

If the second or third syllables of the 
operator are found to be greater than 47 or 
the fourth syllable is greater than 48, the in- 
valid operand interrupt is set and the 
operation is terminated. 



DYNAMIC FIELD TRANSFER (DFTR) (P)99 

The Dynamic Field Transfer operator causes 
a Field Transfer operation using the top-of- 
stack operand to specify the field length, using 
the second operand in the stack to specify the 
starting-bit position of the field from which 
the transfer will be made, and using the third 
operand in the stack to indicate the starting 
bit of the field to which the transfer will be 
made. 

As each of these operands is used to estab- 
lish a pointer for the transfer, it is first inte- 
gerized and checked for being greater than 47 
or 48, as above, then is deleted from the stack. 
The fourth and fifth stack operands become 
the two top-of-stack operands, and the trans- 
fer takes place as in the FLTR operator. 

FIELD ISOLATE (ISOL) (P)9A 

The Field Isolate operator isolates a field in 
the top-of-stack word. The second syllable of 
the operator specifies the starting bit. The 
third syllable specifies the length of the field 
in bits. The isolated field is right-justified with 
all other information bits set to zero. The tag 
bits are not changed. 

DYNAMIC FIELD ISOLATE (DISO) (P)9B 

The Dynamic Field Isolate operator performs 
a Field Isolate operation using the top-of-stack 
operand to specify the length of the field to be 
isolated and using the second operand in the 
stack to specify the starting bit. These oper- 
ands are then deleted from the stack and the 
Field Isolate operation is performed on the 
next operand. 
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Figure 111-3-7. Flow Chart of Evaluate Operator 
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CONCATENATED 
ENTFI 



I 



D 



(NON- \ 

CONCATENATED J 
EN ™ J 



TARGET OF NAMC 
IS LOADED INTO 
A (PREFETCHED 
BY PCU) 
MSCW GOES TO B 



PUSH A AND B 
(IF NECESSARY) 



MSCW ADDRESSED 
BY F IS LOADED 
INTO A (WAS 
PRE-FETCHED 
BY PCU) 



IRW ADDRESSED 
BY F + 1 IS 
LOADED INTO A 
(IRW PRE-FETCHED 
BY PCU) 
MSCW GOES TO B 



FETCH TARGET 
OF IRW 



FETCH TARGET 
OF IRW 





SAVE PCW IN A 
AND W 

SAVE OLD SDI 
IN TIR 




Figure 111-3-8. Flow Chart of Enter Operator (Sheet 1 of 3) 
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FETCH SEGMENT 
DESCRIPTOR 
FROM LOCATION 
DEFINED BY 
DO or D1 + SDI 
(PCW) 




NO 



SET PQR5 



(RCW40-RCW39) 



SET PQR5 
(RCW40-RCW39) 



"••" 




SET POR5 



DISTRIBUTE PCW: 
SDI - PDR 
PIR - APIR 
PSR- SSR 



I 



I 





w 




WRITE F INTO 
D(LL) (DISPLAY 
OFF LL BEING 
ENTERED) 



MAKE RCW FROM 

PRESENT REGISTER 

SETTINGS: 
LL- RCW 18:5 
PST- RCW 19:1 
DSF- RCW13:1 
PQR5- RCW39 1 
PQR6- RCW40 1 

OLD SDI(INTIR) 

- RCW12:13 



I 



OVERWRITE 
MSCW BACK 
INTO F LOCATION 



OVERWRITE 
RCW AT F + 1 




OPERATION 
COMPLETED 



EXTRACT 
PROGRAM BASE 
ADDR. FROM DESC 
AND PLACE IT 
INTO PBR 



FETCH CODE 
FROM LOCATION 
DEFINED BY 

NEW PBR + APIR 



LAST D1 (AU37) 
- LD1 (AU3B) 
SET LD1 




PCW (STK. NO.)- MSCW(45:10) 
DISPLAY-BOS- MSCW(35:16) 
PCW(LL)- MSCW(18:5; 
RVLC-MSCW(19:1) 



Figure 111-3-8. Flow Chart of Enter Operator (Sheet 2 of 3) 
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OBTAIN LAST SIRW 
IN CHAIN FROM EU 
LOCAL STORAGE 
AND EXTRACT 
DISP 



I 



SAVE OLD COPY 
OF D1 IN AU37 



CALCULATE ADDR. 
OF MSCW 
BOS(STK.NO.)+DISP 




FETCH MSCW 
DECREMENT LL 
BY1 



ABORT FETCH 
(UPDATE 
DISPLAY 
COMPLETED) 



RESTORE LL 
AND OBTAIN 
PCW FROM 
EU LOCAL 
STORAGE 





EXTRACT AND 
SAVE BOS FROM 
STACK DESCRIPTOR 
EXTRACT DISP 
FROM MSCW 



RESET PQR6 



YES 



RESET PQR5 




SET PQR5 



-»«- 




FETCH STACK 
DESCRIPTOR 
FROM LOCATION 
DEFINED BY STACK 
VECTOR BASE 
+ STK. NO. (MSCW) 



EXTRACT DISP 
FROM MSCW 



T 



OBTAIN STACK 
VECTOR DESC. 
AT + DO + 2 




YES 



Figure 111-3-8. Flow Chart of Enter Operator (Sheet 3 of 3) 
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EXIT OR 
RETURN 



FETCH MSCW 

AND RCW AT 

DILL) 

SAVE MSCW IN A 



DISTRIBUTE RCW 
SET UP REG TO 
RETURN CALLING 
PROCEDURE 
SAVE CLRRENT 
SDI IN TIR 




SET ESDF 

FETCH SEG. DESC. 

FROM LOCATION 

DEFINED BY DO 

OR D1 (RCW + SDK RCW) 




CUT BACK STACK 

D(OLDLL)- F 

D(OLDLL)-1- S 
SAVED(OLDLL)IN H 




(OLD LL IS THE VALUE 
IN THE LLW REGISTER) 



SET EQR1 
(FETCH OF MSCW 
IS NOT NECESSARY) 



SET ESDF 
FETCH SEG. DESC. 
FROM LOCATION 
DEFINED BY 
,LD1 CONTENTS + 
SDI (RCW) 




EXTRACT PROG. 
BASE ADDRESS 
FROM DESC. AND 
PLACE IT INTO 
PBR 



FETCH CODE 
FROM LOCATION 
DEFINED BY 
NEW PBR + APIR 



(APIR CONTAINS 
PIR OF RCW) 




SET EQRO 




YES 






Figure II 1-3-9. Flow Chart of Exit and Return Operator (Sheet 1 of 3) 
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EXTRACT DF 
FIELD FROM 
MSCW 



I 



CALCULATE 
ADDRESS (H-DF) 
OF NEWEST 
MARK IN STACK 
AND PLACE IT ON 
T BUS AND IN 
F REGISTER 



1 



FETCH MSCW 
AND SAVE 
ADDRESS IN H 



I 



MARK ADD- DLL 





EXTRACT DF 
FIELD FROM 
MSCW 



I 



CALCULATE 
ADDRESS 
(H-DF) OF NEXT 
MARK IN STACK 
AND PLACE IT 
ON THE T BUS 



OPERATION 
COMPLETED 



Figure 111-3-9. Flow Chart of Exit and Return Operator (Sheet 2 of 3) 
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THIS FOR \ YES 
A DIFFERENT ^> 



EXTRACT DISP 
FROM MSCW 


W 


CALCULATE 
ADDRESS OF MSCW 
BOS(STK.NO.) + 
DISP 




OBTAIN STACK 
VECTOR DESC. 
AT DO + 2 




NO 



FETCH MSCW 
DECREMENT 
LL BY 1 




EXTRACT AND 
SAVE BOS FROM 
STACK DESC. 



ABORT FETCH 
(UPDATE 
DISPLAY 
COMPLETED) 





CALCULATED 

ADDRESSAME 

ASOLDD(LL) 

WHICH IS 

VALID 



OBTAIN SEG. 
DESC. 

ADDRESSED BY 
DO OR D1(RCW) + 
PDR 




DOES 
JSCW'S 
\LL = LLREG 



FETCH CODE 
FROM LOCATION 
DEFINED BY 
SEC. DESC BASE- 
APIR 




YES 



OPERATION 
COMPLETED 




WAS 
-JEBIT 
"X. OF MSCW 
\ EQUAL TO 

V 

NO " 



RESUME 
EXECUTION OF 
INTERRUPTED 
VALC OPERATOR 



Figure III-3-9. Flow Chart of Exit and Return Operator (Sheet 3 of 3) 
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FIELD INSERT (INSR) (P)9C 

The Field Insert operator inserts a field 
from the top-of -stack into the second word. 
Stack adjustment assures that the top two po- 
sitions are occupied. The right-justified field in 
the top-of-stack is inserted into the second 
word starting at the position specified by the 
second syllable of the Field Insert operator. 
The third syllable specifies the length of the 
field to be inserted. The top-of-stack word is 
deleted after the field is inserted in the second 
word. 

DYNAMIC FIELD INSERT (DINS) (P)9D 

The Dynamic Field Insert operator performs 
a Field Insert operation, transferring a field 
from the top operand in the stack into the 
fourth operand in the stack. The second oper- 
and in the stack specifies the length of the 
field to be inserted, and the third operand in 
the stack specifies the starting bit of the field. 

TYPE-TRANSFER OPERATORS 

Type-Transfer operators are used to 
manipulate operand relative to single-preci- 
sion or double-precision operands. 

SET TO SINGLE-PRECISION, TRUNCATED (SNGT) 
(P)CC 

The Set to Single-Precision, Truncated 
operator sets the top-of-stack operand to a sin- 
gle-precision operand without rounding. 

SET TO SINGLE-PRECISION ROUNDED (SNGL) (P)CD 

The Set to Single-Precision, Rounded 
operator sets the top-of-stack operand to a sin- 
gle-precision operand with rounding. 

SET TO DOUBLE-PRECISION (XTND) (P)CE 

The Set Double-Precision operator sets the 
top-of-stack operand to a double-precision op- 
erand. 

SET DOUBLE TO TWO SINGLES (SPLT) (V)43 

The Set Double to Two Singles operator 
splits a double-precision operand into two sin- 
gle-precision operands. 

SET TWO SINGLES TO A DOUBLE (JOIN) (V)42 

The Set Two Singles to a Double operator 
joins two single-precision operands to form one 
double-precision operand. 

MISCELLANEOUS PRIMARY MODE 
OPERATORS 

Miscellaneous primary mode operators are 
those operators which cannot be readily de- 
scribed or grouped with other operators. 

ESCAPE TO 16-BIT INSTRUCTION (VARI) (P)95 

The Escape to 16-Bit Instruction operator 
provides transition from the primary mode op- 



erators to the variant mode operators, i.e., the 
first syllable (VARI) indicates that the actual 
operator is in the second syllable. (Interrupts 
are not allowed between the VARI syllable 
and the following syllable.) 

READ AND CLEAR OVERFLOW FLIP-FLOP (ROFF) 

(P)D7 

The Read and Clear Overflow Flip-Flop oper- 
ator places a single-precision operand in the 
top-of-stack with the least-significant bit set 
equal to the overflow flip-flop. The overflow 
flip-flop is reset. 

READ TRUE FALSE FLIP-FLOP (RTFF) (P)DE 

The Read True False Flip-Flop operator 
places a single-precision operand in the top-of- 
stack with the least significant bit set equal to 
the true/false flip-flop. 

SET EXTERNAL SIGN (SXSN) (P)D6 

The Set External Sign operator places the 
operand sign bit of the top-of-stack word into 
the external sign flip-flop. 

STUFF ENVIRONMENT (STFF) (P)AF 

The Stuff Environment operator places the 
current stack number and displacement into 
the stack number field and displacement field 
of the top-of-stack IRW. Bit 46 is set to indi- 
cate that it is now a stuffed indirect reference 
word. 

UNIVERSAL OPERATORS 

The operators NOOP, HALT, and NVLD are 
universal except that they cannot follow oper- 
ators EXSU, EXSD, EXPU, and EXPD; in 
these cases a Loop Timeout will occur. 

CONDITIONAL HALT (HALT) (U)DF 

The Conditional Halt operator halts the proc- 
essor if the conditional halt switch is in the 
ON position; if the conditional halt switch is 
OFF, the operator is treated as a NOOP. 

INVALID OPERATOR (NVLD) (U)FF 

The Invalid Operator sets the invalid- 
operator interrupt. 

NO OPERATION (NOOP) (U)FE 

No operation occurs when the No Operation 
operator is encountered except that the PSR 
and PIR are advanced to point at the next op- 
erator. 

VARIANT MODE OPERATORS 

Variant mode operators is the name used to 
describe those primary mode operators which 
are less frequently used. There is no function- 
al significance to the category "variant mode." 
Variant mode operation extends the number of 
operation codes. Variant mode operators re- 
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quire two syllables: the first syllable is the Es 
cape to 16 Bit Instruction (VAR1) operator 
The syllable following VARI is the actual oper 
atiori and the syllable pointer is positioned be 
yond the two syllables. 

Variant mode codes VEO thru VEF are de 
tected and cause a programmed operator in 
terrupt. All other unassigned variant mode 
codes cause no action and result in a loop tim 
er interrupt. 

Variant mode operations are both word-and 
string-oriented operators. 



SCAN OPERATORS 

SCAN IN (SCNI) (V)4A 

The Scan-In operator uses the 20 low-order 
bits of the top-of-stack word as the address of 
the Time of Day (TOD) register and reads the 
TOD contents to the top-of-stack. Other vari- 
ants, which are valid in the B 6700, produce an 
invalid operand interrupt in the B 7700. The 
B 7700 MCP causes the correct B 7700 code to 
be executed to handle the interrupt. 

SCAN WHILE OPERATORS 

SCAN WHILE GREATER, DESTRUCTIVE (SGTD) (V)F2 

The Scan While Greater, Destructive 
operator scans the number of characters 
specified by the second operand in the stack or 
while the source character is greater than a 
delimiter. The top-of-stack operand is the de- 
limiter. The third item in the stack is the 
source pointer. If the second item in the stack 
is a descriptor, it is used as a source pointer 
and the length of the character string is set to 
1,048,575. All comparisons are binary. When 
the source is an operand, it must be a single- 
precision operand. 

At the completion of this operator if all the 
characters have been scanned the true/false 
flip-flop is set to one. If the scan was stopped 
by the delimiter test before the end of the 
string the true/false flip-flop is set to zero. 

SCAN WHILE GREATER, UPDATE (SGTU) (V)FA 

The Scan While Greater, Update operator 
performs a Scan While Greater, Destructive 
operation. At the completion of the operation, 
the source pointer and count are updated. At 
the completion of the operation, a count of the 
number of characters not scanned is placed in 
the top-of-stack. If all the characters specified 
by the length field are scanned, the true/false 
flip-flop is set to true; otherwise, the true/false 
flip-flop is set to false. The source pointer lo- 
cates the character which stopped the scan. 



SCAN WHILE GREATER OR EQUAL, DESTRUCTIVE 
(SGED) (V)FL 

The Scan While Greater or Equal, Destruc- 
tive operator performs a Scan While Greater, 
Destructive operation while the source charac- 
ter is greater than or equal to the delimiter. 

SCAN WHILE GREATER OR EQUAL, UPDATE (SGEU) 
(V)F9 

The Scan While Greater or Equal, Update op- 
erator performs a Scan While Greater Than or 
Equal, Destructive operation. At the comple- 
tion of the operation, the source pointer and 
count are updated. 

SCAN WHILE EQUAL, DESTRUCTIVE (SEQD) (V)F4 

The Scan While Equal, Destructive operator 
performs a Scan While Greater, Destructive 
operation while the source character is equal 
to the delimiter. 

SCAN WHILE EQUAL, UPDATE (SEQU) (V)FC 

The Scan While Equal, Update operator per- 
forms a Scan While Equal, Destructive 
operation. At the completion of the operation, 
the source pointer and count are updated. 

SCAN WHILE LESS OR EQUAL, DESTRUCTIVE 
(SLED) (V)F3 

The Scan While Less or Equal, Destructive 
operator performs a Scan While Greater, De- 
structive operation while the source character 
is less than or equal to the delimiter. 

SCAN WHILE LESS OR EQUAL, UPDATE (SLEU) 
(V)FB 

The Scan While Less or Equal, Update oper- 
ator performs a Scan While Less or Equal, De- 
structive operation. At the completion of the 
operation, the source pointer and count are 
updated. 

SCAN WHILE LESS, DESTRUCTIVE (SLSD) (V)F0 

The Scan While Less, Destructive operator 
performs a Scan While Greater, Destructive 
operation while the source character is less 
than the delimiter. 



SCAN WHILE LESS, UPDATE (SLSU) (V)F8 

The Scan While Less, Update operator per- 
forms a Scan While Less, Destructive 
operation. At the completion of the operation, 
the source pointer and count are updated. 

SCAN WHILE NOT EQUAL, DESTRUCTIVE (SNED) 
(V)F5 

The Scan While Not Equal, Destructive oper- 
ator performs a Scan While Greater, Destruc- 
tive operation while the source character is 
not equal to the delimiter. 
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SCAN WHILE NOT EQUAL, UPDATE (SNEU) (V)FD 

The Scan While Not Equal, Update operator 
performs a Scan While Not Equal, Destructive 
operation. At the completion, the source point- 
er and count are updated. 

SCAN WHILE TRUE, DESTRUCTIVE (SWTD) (V)D5 

The Scan While True, Destructive operator 
uses each source character as an index into a 
table to locate a bit in the table. In order to in- 
dex the table the source character is expanded 
to eight bits (if necessary) by appending two or 
four leading-zero bits. The three high-order 
bits of these eight select a word from the ta- 
ble, indexing the table pointer. The remaining 
five bits of the expanded source character se- 
lect a bit from this word by their value. If the 
bit located is a one, the relationship is true 
and the scan continues. An all zero's character 
indexes to the most significant bit of the table. 
The top-of -stack word is a table pointer. The 
second item in the stack specifies the number 
of characters to be scanned or, if it is a de- 
scriptor, it is used as a source pointer and the 
length of the character string is set at 
1,048,575. The third item in the stack is the 
source pointer. If all the characters specified 
by the length field are scanned, the true/false 
flip-flop is set to true; otherwise, the true/false 
flip-flop is set to false. At the completion of 
the operation, a count of the number of char- 
acters not scanned is placed on the top of 
stack. The table format is as follows: 



Source Size 

4 
6 
8 



Table Length 

1 word 

2 words 
8 words 



Bits/Word 

(31:16) 
(31:32) 
(31:32) 



SCAN WHILE TRUE, UPDATE (SWTU) (V)DD 

The Scan While True, Update operator per- 
forms a Scan While True, Destructive 
operation. At the completion of the operation, 
the source pointer and count are updated. 

SCAN WHILE FALSE, DESTRUCTIVE (SWFD) (V)D4 

The Scan While False, Destructive operator 
performs a Scan While True, Destructive oper- 
ation except that the relationship is true if the 
bit found by indexing into the table is a zero. 

SCAN WHILE FALSE, UPDATE (SWFU) (V)DC 

The Scan While False, Update operator per- 
forms a Scan While False, Destructive 
operation. At the completion of the operation, 
the source pointer and count are updated. 



TAG FIELD OPERATORS 

SET TAG FIELD (STAG) (V)B4 

The Set Tag Field operator sets the tag field 
(bits 50:3) of the second word in the stack to 
the contents of bits 2:3 of the top-of-stack 
word. 

READ TAG FIELD (RTAG) (V)B5 

The Read Tag Field operator replaces the 
top-of-stack word with a single-precision oper- 
and with bits 2:3 equal to the tag field of the 
original top-of-stack word. 



SET INTERVAL TIMER (SINT) (V)45 (CONTROL STATE 
OPERATOR) 

The Set Interval Timer operator integerizes 
the top-of-stack operand. If the operand can- 
not be integerized, an integer-overflow inter- 
rupt is set and the operation is terminated. 
The value of the 11 low-order bits of the top- 
of-stack operand is used to set the interval 
timer associated with the processor which is 
executing this operator. Once set, the interval 
timer will start to decrement once each 512 mi- 
croseconds. The associated processor is inter- 
rupted when the value has been counted to 
zero if the timer is still armed. 

The interval timer is disarmed whenever the 
associated processor is interrupted by an ex- 
ternal interrupt. 

READ PROCESSOR IDENTIFICATION (WHOI) (V)4E 

The Read Processor Identification operator 
places a single-precision operand with a value 
equal to the processor's number on the top-of- 
stack. 

ENABLE EXTERNAL INTERRUPTS (EEXI) (V)46 

The Enable External Interrupts operator al- 
lows this processor to respond to external in- 
terrupts. 

DISABLE EXTERNAL INTERRUPTS (DEXI) (V)47 

The Disable External Interrupts operator 
prohibits this processor from responding to ex- 
ternal interrupts. 

IDLE UNTIL INTERRUPT (IDLE) (V)44 

The Idle Until Interrupt operator suspends 
program execution by this processor. External 
interrupts are allowed, and the processor will 
enter its interrupt-handling routine upon re- 
ceipt of an interrupt. 

READ PROCESSOR REGISTER (RPRR) (V)B8 

The Read Processor Register operator reads 
into the top-of-stack the contents of one of the 
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eight base registers, or one of the eight index 
registers, or one of the 32 D registers. Register 
address assignments are as follows: 



Register Usage 

Display Registers 
Program Index 
Source Index 
Destination Index 
Table Index 
Limit of Stack 

Base of Stack 
Most Recent MSCW Address 
Scratch (Spare Local Storage) 
Interrupt Identifier 

MDP Control Register 
Interrupt Mask Register 
Spare 

Interrupt Fault Register 
Spare 

Interval Timer 
Time of Day 
Program Base Register 
Source Base Register 
Destination Base Register 
Table Base Register 
Top of Stack Address 
Current Stack Vector Index 
Current Segment Descriptor 
Irdex 

Scratch (Spare Local Storage) 
Alternate [DO] Register 
Alternate Program Index 
All ones 

Last D [ 1 ] used as SD1 

base. 

Processor Fail Register 

Processor Mode Register 

Purge Associative Memory 
Purge Stack and Associative 
Memory 



"Local Memory Register 

An invalid-operator interrupt is set and the 
operation is terminated if the top-of-stack 
word is not a descriptor or an indirect refer- 
ence word at the start of the Evaluate 
operator. 

SET PROCESSOR REGISTE R (SPRR) (V)B9 

The Set Processor Register operator sets the 
processor register addressed by the second 
word in the stack to the value contained in the 
top-of-stack word. On every SPRR the con- 
tents of the stack buffer are purged and 
stored in main memory. 



Add. 


Add. 


Reg. 


dec.) 


(hex) 


Name 


0-31 


0-1F 




32 


20 


PIR 


33 


21 


SIR* 


34 


22 


DIR* 


35 


23 


TIR* 


36 


24 


LOSR 


37 


25 


BOSR" 


38 


26 


F 


39 


27 


S1LS* 


40 


28 


ID 


41 


29 


SCAN" 


42 


2A 


IMR 


43 


2B 




44 


2C 


IFR 


45 


2D 




46 


2E 


INT 


47 


2F 


TOD 


48 


30 


PBR* 


49 


31 


SBR* 


50 


32 


DBR* 


51 


33 


TBR* 


52 


34 


S 


53 


35 


SNR* 


54 


36 


PDR* 


55 


37 


S2LS* 


56 


38 


ADZ* 


57 


39 


APIR* 


58 


3A 


ALL1* 


59 


3B 


LD1* 


60 


3C 


PFR 


61 


3D 


PMR 


62 


3E 


PGAM 


63 


3F 


PGKA 



UNPACK OPERATORS 

UNPACK ABSOLUTE, DESTRUCTIVE (UABD) (V)D1 

The Unpack Absolute, Destructive operator 
unpacks a string of left-justified digits from 
the second operand in the stack. The top-of- 
stack operand defines the string length (in 4- 
bit digits) of the second operand in the stack. 
The specified number of digits are transferred 
from the second operand to the destination. 
The third item in the stack is a string descrip- 
tor destination pointer. Zone fill in the desti- 
nation is as follows: 

1. If the destination bit format is 8-bit 
ASCII, the digits are transferred to the desti- 
nation string with the leading-zone bits set to 
0011. 

2. If the destination bit format is 6-bit BCL, 
the digits are transferred to the destination 
with the two leading-zone bits set to zero. 

3. If the destination bit format is 8-bit EBC- 
DIC, the digits are transferred to the destina- 
tion string with the four leading-zone bits set 
to one. 

4. If the destination character size is 0, it is 
set to 6 and the digits are transferred to the 
destination string with the two leading-zone 
bits set to zero (BCL). 



UNPACK ABSOLUTE, UPDATE (UABU) (V)D9 

The Unpack Absolute, Update operator per- 
forms an Unpack Absolute, Destructive 
operation. At the completion of the operation 
the destination pointer is updated. 

UNPACK SIGNED, DESTRUCTIVE (USND) (V)D0 

The Unpack Signed, Destructive operator 
performs an Unpack Absolute, Destruction op- 
eration except that the external sign is consid- 
ered. 

If the external sign flip-flop is ON (indicat- 
ing negative data) then a zone of 10 is inserted 
in the last 6-bit character or a zone of 1101 is 
inserted in the last 8-bit byte. For 8-bit ASCII 
formatted data the negative sign is indicated 
in the least-significant byte by a zone of 1111. 
If the data format of the destination is 4 bits, 
the first digit position of the destination string 
is set to 1101 if the external sign flip-flop is 
ON; if the external sign flip-flop is OFF the 
first digit of the destination string is set to 
1100. 
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UNPACK SIGNED, UPDATE (USNU) (V)D8 

The Unpack Signed, Update operator per- 
forms an Unpack Signed, Destructive 
operation. At the completion of the operation 
the destination pointer is updated. 

LINKED LIST LOOKUP (LLLU) (V)BD 

The Linked List Lookup operator searches a 
linked list of words. 

This operator expects the third stack entry 
(bits 27:28) to contain an argument, the second 
stack entry to contain a non-indexed data de- 
scriptor, and the top-of-stack to contain an op- 
erand index value pointing into a linked-list of 
words. The argument is not required to be an 
integer, but only the right-most 28 bits are sig- 
nificant after the argument has been inte- 
gerized as required. The base address, size 
field, and argument are saved throughout the 
operator. 

The word addressed by the base plus the in- 
dex value is read into local storage. Bits 47:28 
are compared to the argument value. If the ar- 
gument of the linked-list word is less than the 
argument value, this process is repeated using 
the link as the new index. If the linked-list ar- 
gument is greater than or equal to the argu- 
ment value, the operation is complete. At com- 
pletion the top-of-stack register contains an in- 
dex which points to the link that points to the 
satisfying argument. 

If the value of the link portion of the linked- 
list word is equal to zero, the top-of-stack reg- 
ister is set to minus one (-1) and marked full 
as the operation is completed. 

If the index value in the linked-list word is 
greater than the length value from the de- 
scriptor, an invalid-index interrupt is set and 
the operation is terminated. 

When the first word in the stack at the start 
of this operator is not an operand an invalid- 
operand interrupt is set and the operation is 
terminated. 

If the data descriptor has been indexed, the 
invalid-operand interrupt is set and the 
operation is terminated. 

MASKED SEARCH FOR EQUAL (SRCH) (V)BE 

The Masked Search for Equal operator 
searches a data word list for a word identical 
to the third word in the stack. At the be- 
ginning of this operator, the top word in the 
stack contains a data descriptor, the second 
word in the stack contains a 51-bit mask, and 
the third word in the stack contains a 51-bit 
argument value. If the descriptor is not pres- 
ent, the presence-bit interrupt is set and the 
operator is exited. Otherwise, if the descriptor 
is indexable (i.e., bit 45 equals zero), the in- 
dexed bit (bit 45) is turned ON and the length/ 
index field value is decreased by 1. 



The descriptor points to a word which is 
then fetched into the processor. This word is 
ANDed with the mask and a test is made to 
determine whether the result is identical to 
the argument. 

When an equal compare is made, the second 
stack register is marked empty; the top-of- 
stack contains an index which gives the ad- 
dress of the last word inspected. 

When a not-equal compare is made, the in- 
dex value is decreased by one and the 
operation is repeated (except when the index 
value is zero). When the index value is zero, 
the top-of-stack register is set to -1 and 
marked full, the second stack register is 
marked empty, and the operator is exited. 



MOVE TO STACK (MVST) (V)AF 

The Move to Stack operator causes the proc- 
essor's environment (or addressing space) to 
terminate and to be moved from the current 
stack to the program stack specified by the op- 
erand in the top of stack. 

The operator builds a top-of-stack control 
word and places it at the base of the current 
stack as addressed by the base-of-stack regis- 
ter. 

The operand in the B register is integerized 
and checked for invalid index against the 
stack vector. The value in the B register is 
added to the address field of the stack vector 
descriptor (at D[0[+2), to address the descrip- 
tor for the new stack. 

The data descriptor for the requested stack 
is accessed. If its presence bit is ON, the ad- 
dress field is placed into the base-of-stack reg- 
ister. The top-of-stack control word is brought 
up and the stack is marked "active" by storing 
the processor ID at the base of the stack. The 
TSCW is distributed and the D registers are 
updated. 



If during the integerization the operand in 
the B register is too large, the integer-over- 
flow interrupt is set and the operation is ter- 
minated. The stack buffer is purged on every 
execution of MVST. 

If the index value is less than zero or great- 
er than the length field of the data descriptor 
for the stack vector array, an invalid index in- 
terrupt is set and the operation is terminated. 
OCCURS INDEX (OCRX) (V)85 

The Occurs Index operator is used to index a 
field in an array. This operator requires an Oc- 
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curs Index Word (OIW) in the top-of-stack and 
an index value (operand) in the second stack 
position. The format of the IOW is shown be- 
low. 





47 


43 


39 


35 


31 


27 
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The operator creates a new index value from 
the OIW and the operand in the following 
manner: 

The operand is integerized. If the resulting 
index is greater than the maximum integer 
value (549,755,813,887), the integer overflow in- 
terriipt is set and the operation is terminated. 
If either the OIW or the index has a value of 
zero, or if the index is less than zero or great- 
er than the SIZE field of the OIW, the invalid 
index interrupt is set and the operation is ter- 
minated. 

The LENGTH field of the OIW is multiplied 
by the index value ±15:161 minus 1, and that 
value is added to the OFFSET field of the 
IOW, resulting in the new index value. The 
two original top-of-stack items are deleted and 
the new index value is left in the top-of-stack.. 

In the IOW the "length" field gives the num- 
ber of characters in a field; the "size" field 
gives the number of fields in the array; the 
"offset" field indicates the beginning of the 
first character position in the first field of the 
first word. 

TRANSLATE (TRNS) (V)D7 

The Translate operator transfers from the 
source to the destination the number of char- 
acters specified by the second item in the 
stack while performing the following transla- 
tion. 

The translation uses a table containing the 
translated characters. The word in the top-of- 
stack is a descriptor that addresses the trans- 
lation table. The second operand in the stack 
specifies the length of the string. The third 
word in the stack is a descriptor addressing 
the source string (or an operand which is the 
source string). The fourth word in the stack is 
a descriptor addressing the destination string. 
Source and destination are updated at the end 
of the operation. 

Translation occurs as follows: The specified 
string character is used as index into the table 
to locate a character. An all zeroes character 



locates the most significant character in the 
table. The located character is transferred to 
the destination string. 

The least significant 32 bits of each table 
word provide four 8-bit characters. Table sizes 
are as follows: 

a. 4-bit digits provide a 4-word table length. 

b. 6-bit characters provide a 16-word table 
length. 

c. 8-bit bytes provide a 64-word table length. 
OPERATORS EXCLUSIVE TO THE B 7700 

If ATE E OP) RY INHIBITS (SINH) WA8 (CONTROL 

The Set Memory Inhibits operator transfers 
the inhibit settings in the second stack regis- 
ter to the memory module specified in the top 
stack register. The two top-of-stack registers 
are marked empty. (All tags are legal.) The 
memory module number is given in the top-of- 
stack (bits 3:4). The inhibit field setting is giv- 
en in the second item in the stack (bits 7:8). 

SET MEMORY LIMITS (SLMT) (V)AA (CONTROL STATE 
OP) 

The Set Memory Limits operator transfers 
the limits and availability settings in the sec- 
ond stack register to the memory module spec- 
ified in the top-of-stack register. The two top- 
of-stack registers are then marked empty. (All 
tags are legal.) The limits specify the range of 
addresses (in 16K increments) behind the mod- 
ule and the availability setting specifies which 
stack(s) (of a possible four) are to be used. (All 
tags are legal.) The top-of-stack gives the 
memory module number (bits 3:4). The second 
item in the stack gives module availability 
(bits 3:4) and memory addressing limits: upper 
limit (bits 15:6) and lower limit (bits 9:6). 

FETCH MEMORY FAIL REGISTER (FMFR) (V)AC 
(CONTROL STATE OP) 

The Fetch Memory Fail Register operator 
fetches the contents of the fail register from 
the memory module specified in the top-of- 
stack (bits 3:4). The contents of the fail regis- 
ter are placed in the top-of-stack. 

IGNORE PARITY (IGPR) (V)48 (CONTROL STATE OP) 

The Ignore Parity operator is used for confi- 
dence checking and requires the processor to 
be in the control state. In control mode 0, 
words entering the CPM are checked for cor- 
rect parity but the IGPR operator sets the IGP 
flip-flop which inhibits transmission of parity 
error messages for those words with incorrect 
parity. Likewise, IGPR inhibits correct parity 
generation before storage for those words de- 
tected in the CPM with incorrect parity. 

Parity error interrupts and new parity gen- 
eration will be inhibited with the CPM in con- 
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trol mode by IGPR until any one of the fol- 
lowing occurs: 

1. Some other interrupt causes the CPM to 
move to control mode 1. 

2. Another IGPR is decoded while the CPM 
is in a control mode greater than zero. 

3. Or the CPM returns to normal state. 
Any one of the above conditions cause the 

IGP flip-flop to be reset and the CPM to resu- 
me parity error interrupts and generation of 
new parity. 

PAUSE UNTIL INTERRUPT (PAUS) (V)84 

The Pause Until Interrupt operator suspends 
program execution until an external interrupt 
or an interval timer interrupt occurs. If the 
processor is operating in control state, the op- 
eration continues in sequence; to clear the in- 
terrupt the INT. I.D. must be read. If the 
processor is operating in normal state, the in- 
terrupt is handled as in IDLE. 

INTERRUPT CHANNEL N (INCN) (V)8F 

The Interrupt Channel N operator sends sig- 
nals to the channel or channels specified by 
the top-of-stack. The top-of-stack is then 
marked empty. Bit interrupts channel 0; bit 
1 interrupts channel 1; etc. 

STOP (STOP) (V)BF 

The STOP operator causes an unconditional 
halt of the central processor. The STOP 
operator is primarily used for diagnostic pur- 
poses. The processor may be restarted by pres- 
sing and releasing the START button on the 
processor control panel. 

EDIT MODE OPERATORS 

Edit Mode operators perform editing func- 
tions on strings of data. Edit functions are 
normally involved in preparing information 
for output. These operators include Insert, 
Move, and Skip, in the form of micro-operators 
in either the program string or in a separate 
table. In the program string, they are single 
micro-operators and are entered by use of the 
Execute Single Micro or Single Pointer 
operators. (See the "Enter Edit Mode 
Operator" descriptions.) If the micro-operators 
are in a table, the table becomes the program 
string that is to be executed. This table is en- 
tered by means of the Table Enter Edit 
operators, and is exited through the End Edit 
micro-operator. 

If the source or destination data has the 
memory protect bit (bit 48) equal to one, the 
segmented-array interrupt is set and the cur- 
rent micro-operator is terminated. 



INSERT OPERATORS 

INSERT UNCONDITIONAL (INSU) (E)DC 

The Insert Unconditional micro-operator 
places an insert character into the destination 
string for the number of times specified by the 
repeat value. When this operator is entered by 
a Table Enter Edit operator, the repeat is in 
the syllable following the micro-operator sylla- 
ble, and the insert character is in the next syl- 
lable (the third syllable). 

When this operator is entered via an 
Execute Single Micro Instruction operator, the 
repeat field is in the top-of-stack operand and 
the insert character is the second syllable. The 
operator length is then two syllables. 

INSERT CONDITIONAL (INSC) (E)DD 

The Insert Conditional operator inserts the 
character defined by the third syllable into the 
destination string if the float toggle is OFF. If 
the float toggle is ON, the character defined 
by the fourth syllable is inserted into the des- 
tination string. The insertion is repeated the 
number of times specified by the second sylla- 
ble when this operator is entered by the Table 
Enter Edit operation. 

When this operator is entered via an 
Execute Single Micro Instruction operator, the 
repeat field is the top-of-stack operand. The 
operator length is then three syllables. 

INSERT DISPLAY SIGN (INSG) (E)D9 

The Insert Display Sign operator inserts the 
character defined by the second syllable into 
the destination string if the external sign flip- 
flop is set; otherwise, the character defined by 
the third syllable is inserted. 

INSERT OVERPUNCH (INOP) (E)D8 

The Insert Overpunch micro-operator places 
a sign overpunch in the destination string 
character. If the external sign flip-flop is re- 
set, the operator skips one destination string 
character. If the external sign flip-flop is set, 
the zone bits of the destination character are 
set to 10 for 6-bit data and to 1101 for 8-bit 
EBCDIC data; the destination pointer is then 
advanced one character. The zone bits for 8-bit 
ASCII data are set to 1111. 
MOVE OPERATORS 

MOVE WITH INSERT (MINS) (E)D0 

The Move With Insert micro-operator per- 
forms a Move Numeric Unconditional or an In- 
sert operation under control of the float flip- 
flop. 

If the float flip-flop is set, a Move Numeric 
Unconditional operation is performed. If the 
float flip-flop is reset and the source character 
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numeric is zero, the character defined by the 
third syllable is transferred to the destination 
string. If the float flip-flop is reset and the 
source character numeric is not zero, then the 
float flip-flop is set and a Move Numeric Un- 
conditional is performed. 

The number of characters transferred from 
the source string to the destination string is 
defined by the repeal; value. In Table Edit 
mode the second syllable is the repeat value 
and the third syllable is the character to be in- 
serted under control of the float flip-flop. In 
Execute Single Micro mode the repeat field 
value is in the word in the top-of -stack and the 
insert character is in the syllable following the 
micro-operator syllable. 



MOVE WITH FLOAT (MFLT> (E)D1 

If the float flip-flop is set, the Move with 
Float operator causes a Move Numeric Uncon- 
ditional operation to be performed. 

If the float flip-flop is reset and the source 
character numeric is zero, then the character 
defined by the third syllable is transferred to 
the destination string. 

If the float flip-flop is reset and the source 
character numeric is not zero, then the float 
flip-flop is set. If the external sign flip-flop is 
set, the character defined by the fourth sylla- 
ble (the second insert character) is transferred 
to the destination string; otherwise, the char- 
acter defined by the fifth syllable (the third 
character) is transferred. Then a Move Nu- 
meric Unconditional operator is performed. 

In Table Edit mode, the above operation is 
repeated for the number of characters 
specified by the second syllable; the third, 
fourth, and fifth syllables are the insert char- 
acters. 

When this operand is entered via an Execute 
Single Micro instruction, the repeat field is the 
top-of-stack operand. The operand length is 
then four syllables, three of which contain in- 
sert characters. 

MOVE CHARACTERS (MCHR) (E)D7 

The Move Characters operator transfers the 
number of characters specified by the second 
syllable from the source string to the destina- 
tion string, if the operator is entered this by 
the Table Enter Edit, Destructive operator. 

When this operator is entered via an 
Execute Single Micro Destructive instruction, 
the number of characters transferred is 
specified by the top-of stack operand. The op- 
erator length is then one syllable. 

MOVE NUMERIC UNCONDITIONAL (MVNU) <E)D6 

The Move Numeric Unconditional operator 
transfers from the source string to the desti- 



nation string the number of characters 
specified by the second syllable. The zones are 
not transferred but are set to 00 for 6-bit data, 
to 1111 for 8-bit EBCDIC data, and to 0011 for 
8-bit ASCII data. 

When this operator is entered via an 
Execute Single Micro instruction, the number 
of characters transferred is specified by the 
top-of-stack operand. The operator length is 
then one syllable. 

SKIP OPERATORS 

SKIP FORWARD SOURCE CHARACTERS (SFSC) (E)D2 
The Skip Forward Source Characters 
operator causes a skip forward for the number 
of source characters specified by the syllable 
following the micro-operator's syllable, if the 
entry to this operator is by the execution of 
the Table Enter Edit operator. When this op- 
erator is entered via an Execute Single Micro, 
Destructive instruction, the number of charac- 
ters skipped is specified by the top-of-stack op- 
erand. The operator length is then one sylla- 
ble. 

SKIP REVERSE SOURCE CHARACTERS (SRSC) (E)D3 

The Skip Reverse Source Characters 
operator decrements the source pointer regis- 
ter for a skip in reverse for the number of 
source characters specified by the second syl- 
lable. 

SKIP FORWARD DESTINATION CHARACTERS (SFDC) 
(E)DA 

The Skip Forward Destination Characters 
operator causes a skip forward for the number 
of destination characters specified by the sec- 
ond syllable. 

SKIP REVERSE DESTINATION CHARACTERS (SRDC) 
(E)DB 

The Skip Reverse Destination Character op- 
erator causes a skip in reverse for the number 
of destination characters specified by the sec- 
ond syllable. 



RESET FLOAT (RSTF) (E)D4 

The Reset Float micro-operator sets the float 
flip-flop to zero. 

END FLOAT (ENDF) (E)D5 

The End Float operator transfers to the des- 
tination string the character defined by the 
second syllable if the float flip-flop is reset 
and the external sign flip-flop is set. 

If the float flip-flop is reset and the external 
sign flip-flop is reset, the character defined by 
the third syllable is transferred to the destina- 
tion string. 

If the float flip-flop is set, the End Float op- 
erator is treated as a NO-OP. 
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END EDIT (ENDE) (E)DE 

The End Edit operator terminates the execu- 
tion of this string of edit micro-operators in 
Table Enter Edit mode. The micro program 
string must end with the End Edit operator. 

UNIVERSAL OPERATORS 

NO OPERATION (NOOP) (U)FE 

No operation takes place when the NOOP op- 
erator is encountered. The program index reg- 
ister (PIR) and the program syllable register 
(PSR) are advanced to the next syllable. This 
operator is valid in Variant Mode and Edit 
Mode but is not valid in Single Micro mode. 

CONDITIONAL HALT (HALT) (U)DF 

This operator halts the processor if the con- 
ditional halt switch is in the ON position. If 
the conditional halt switch is OFF, the 
operator is treated as a NOOP. This operator 
is valid in Variant Mode and Edit Mode but is 
not valid in Single Micro mode. 

INVALID OPERATOR (NVLD) (U)FF 

This operator sets the invalid operand inter- 
rupt. 



VECTOR MODE OPERATORS 

Certain scientific and mathematical analysis 
involves manipulation of vectors and matrices. 
Programming wise a vector is a string of num- 
bers which may be a row, a column, or a 
diagonal in an array of numbers. Operations 
may be performed on each item in the vector, 
on multiple vectors, between vectors, on a ma- 
trix of numbers within the array, between ma- 
trices, etc. Seventy-seven operators are avail- 
able for vector (arithmetic, logical, relational, 
etc.) manipulations. (The two operators (VMOS 
and VMOM) used to enter vector mode 
operation are described in the primary mode 
section of this document.) 

In vector mode, the source, destination, and 
table pointer areas are used as index registers. 
Absolute addresses and their corresponding in- 
crements of items in the vector are extracted 
from the stack by VMOS or VMOM and placed 
in the index registers. The stack initially con- 
tains three descriptors and three or four oper- 
ands: If bit 44 of the descriptor in the top of 
erand and is stored as the repeat count; other- 
wise, a default repeat of 1,048,575 is used. 
Each of the three descriptors represents a full 
or partial array of operands to be operated up- 
on by the repetition of the word of code. 

Vector mode operation is entered via the 
VMOS operator for a single-word vector mode 
operation or via the VMOM operator for multi- 



ple-word vector mode operations. The enter 
vector operators extract three absolute ad- 
dresses, their corresponding increment, and an 
optional length from the stack and place them 
as index registers in the pointer areas of the 
IC memory. Vector stack operators load, store, 
or increment the top-of-stack with a single- 
precision or a double-precision operand for sin- 
gle program word loops or for multiple pro- 
gram word loops. 

The number of program iterations is indi- 
cated by "length." Following the enter vector 
mode instruction, up to five syllables are ig- 
nored and the next full program word is 
fetched into the P register. If a repeat (length) 
is specified, this word will be executed that 
number of times. (If the repeat is not given, 
the execution is controlled by the operator it- 
self.) In VMOM the number of program 
operators accessed is controlled by the 
operators Vector Branch and Vector Exit. 
Only those operators listed below (by mnemon- 
ic) may be used to manipulate vectors or ma- 
trices in vector mode. 

Operator Type Mnemonics of Operators Permitted in 

Vector Mode 

Arithmetic ADD DIVD IDIV MULT MULX NTGD 

NTGR NTIA RDIV SUBT 

Bit BRST BSET CBON CHSN DBRS 

DBST LOG2 

Literal Call ONE LT8 LT16 LT48 MPCW ZERO 

Logical LAND LEQV LNOT LOR 

Relational EQUL GREQ GRTR LESS LSEQ 

NEQL SAME 

Scale DSLF DSRF DSRR DSRS DSRT SCLF 

SCRF SCRS SCRT 

Stack DLET DUPL EXCH PUSH RSDN 

RSUP 

Type Transfer JOIN SNGL SNGT SPLT XTND 

Transfer DFTR DISO DINS FLTR INSR ISOL 

Branch BRFL BRTR BRUN 

Unpack LLLU 

Tag Field OCRX RPRR RTAG SINT SPRR STAG 

WHOI 

Index Load LODT 

Universal HALT 

Miscellaneous ROFF RTFF SXSN VARI 
Primary Mode 

Operators DADD FMFR IGPR INCN MAX MIN 

Exclusive to PAKL PAKR RDEF ROD2 ROD1 
the B 7700 UPKL UPKR 

VECTOR BRANCH (VEBR) (Z)EE 

Vector Branch is a three-syllable operator. 
The two syllables following the operator name 
contain the branch address. Vector Branch ex- 
amines length. If it is greater than zero. 
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length is decremented by one, the next two 
program syllables containing the branch ad- 
dress are skipped, and the program is resumed 
at the following syllable. If the examined 
length is zero, vector mode is exited, and nor- 
mal operation commences with the program 
word located by the branch address. 

VECTOR EXIT (VXIT) (Z)E6 

The Vector Exit operator causes the pro- 
gram to return to normal operation. 

VECTOR STACK OPERATORS 

Vector stack operators store or load the top 
of stack from absolute memory addresses with 
a single-precision or double-precision operand, 
and, if specified, increment the loading or stor- 
ing address. 

LOAD A (LDA) (Z)E0 

The stack is adjusted (0,2) and the single-pre- 
cision word selected by Pointer A is loaded 
into the top of stack. 

LOAD B (LDB) (Z)E2 

The stack is adjusted (0,2) and the single-pre- 
cision word selected lay Pointer B is loaded 
into the top of stack. 

LOAD C (LDC) (Z)E4 

The stack is adjusted (0,2) and the single-pre- 
cision word selected by Pointer C is loaded into 
the top of stack. 

LOAD A, INCREMENT (LDAI) (Z)E1 

The stack is adjusted (0,2) and the single-pre- 
cision word selected by Pointer A is loaded 
into the top of stack. Pointer A is increased by 
its increment following the transfer. 

LOAD B, INCREMENT (LDBI) (Z)E3 

The stack is adjusted (0,2) and the single-pre- 
cision word selected by Pointer B is loaded 
into the top of stack. Pointer B is increased by 
its increment following the transfer. 

LOAD C, INCREMENT (LDCI) (Z)E5 

The stack is adjusted (0,2) and the single-pre- 
cision word selected by Pointer C is loaded into 
the top of stack. Pointer C is increased by its 
increment following the transfer. 

STORE A (STA) (Z)F0 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer A. 

STORE B (STB) (Z)F2 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer B. 



STORE C (STC) (Z)F4 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer C. 

STORE A, INCREMENT (STAI) (Z)F1 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer A. Pointer A is in- 
creased by its increment following the trans- 
fer. 

STORE B, INCREMENT (STBI) (Z)F3 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer B. Pointer B is in- 
creased by its increment following the trans- 
fer. 

STORE C, INCREMENT (STCI) (Z)F5 

The stack is adjusted (1,2) and the single-pre- 
cision word in the top of stack is stored in the 
location given by Pointer C. Pointer C is in- 
creased by its increment following the trans- 
fer. 

DOUBLE LOAD A (DLA) (Z)E8 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer A is loaded 
into the top of stack. 

DOUBLE LOAD B (DLB) (Z)EA 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer B is loaded 
into the top of stack. 

DOUBLE LOAD C (DLC) (Z)EC 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer C is loaded 
into the top of stack. 

DOUBLE LOAD A, INCREMENT (DLAI) (Z)E9 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer A is loaded 
into the top of stack. Pointer A is increased by 
its increment following the transfer. 

DOUBLE LOAD B, INCREMENT (DLBI) (Z)EB 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer B is loaded 
into the top of stack. Pointer B is increased by 
its increment following the transfer. 

DOUBLE LOAD C, INCREMENT (DLCI) (Z)ED 

The stack is adjusted (0,2) and the double- 
precision word selected by Pointer C is loaded 
into the top of stack. Pointer C is increased by 
its increment following the transfer. 

DOUBLE STORE A (DSA) (Z)F8 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer A. 
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DOUBLE STORE B (DSB) (Z)FA 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer B. 

DOUBLE STORE C (DSC) (Z)FC 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer C. 

DOUBLE STORE A, INCREMENT (DSAD (Z)F9 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer A. Pointer A is 
increased by its increment following the trans- 
fer. 

DOUBLE STORE B, INCREMENT (DSBI) (Z)FB 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer B. Pointer B is 
increased by its increment following the trans- 
fer. 

DOUBLE STORE C, INCREMENT (DSCI) (Z)FD 

The stack is adjusted (1,2) and the double- 
precision word in the top of stack is stored in 
the location given by Pointer C. Pointer C is 
increased by its increment following the trans- 
fer. 



VECTOR FETCH AND STORE OPERATORS 

The Vector Fetch and Vector Store operators 
are used in conjunction with addresses 
relative to a Mark Stack Control Word (only 
when a "length" is passed) to load or store op- 
erands to or from the top-of-stack. The oper- 
ands are moved to or from the memory loca- 
tion indicated by the normal address-couple 
decoding convention (as in Value Call) unless 
the memory location is protected. (An attempt 
to access a protected memory location causes a 
vector mode exit and a memory protect inter- 
rupt.) A single-precision operand is placed in 
the top-of-stack position designated AO. A dou- 
ble-precision operand uses both the 9 s and the 9 q 
osition of the top-of-stack; the least 
significant half of the mantissa is placed in 
the'q position. 



The format of the Vector Fetch and Vector 
operators is: 







LS 



next syllable 



J 



address couple 

where, if 

LS=0 then load (FTCH operator) or when 

LS=1 then store (STOR operator). 

Certain precautions must be exercised in 
using the Fetch and Store operators. It must 
be assured that: 

a. Words being loaded or stored are oper- 
ands. 

b. The precision of the operand to be stored 
agrees with that of the receiving location. 

c. The address couple does not reference a 
lexicographical level which is higher than the 
level in which the address couple is now. 

VECTOR FETCH (FTCH) (ZXK) THRU (Z)3F 

The Vector Fetch operator loads into the top- 
of-stack the operand referenced by this ad- 
dress couple of this operator. The address cou- 
ple is formed by the concatenation of the siz 
low-order bits of the first syllable of this oper- 
ator with the eight bits of the second syllable 
of this operator. The address couple (in the 
stack) references a memory storage location 
relative to an MSCW. The operand may be sin- 
gle precision or double precision, thus, one or 
two words will be loaded, respectively. 

After the operand is brought to the top-of- 
stack, the top-of-stack is marked full. 

VECTOR STORE (STOR) (Z)40 THRU (Z)7F 

The Vector Store operator stores single-pre- 
cision or double-precision operands from the 
top-of-stack into a memory area relative to an 
MSCW. The least significant six bits of the 
first syllable of the STOR operator are concat- 
enated with the eight bits of the second sylla- 
ble of the STOR operator to form an address 
couple which links the storage area with the 
MSCW. 

After the operand is stored, the operand and 
its address are deleted from the stack. 
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CHAPTER IV 
INPUT/OUTPUT SUBSYSTEM 



SECTION 1 



GENERAL DESCRIPTION AND OPERATION OF THE INPUT/OUTPUT 

MODULE 



PRELIMINARY 

The B 7700 Input/Output Module, is de- 
signed to serve as a buffer and control unit for 
all B 7700-system input; and output data trans- 
fers. The IOM services requestors from a 
queue of requests constructed by the Central 
Processing Module (CPM) and stored in the 
Memory Storage Unit (MSU),. 

The IOM is informed, via an interrupt from 
the CPM, of the presence of a service request 
in the MSU. Once informed, the IOM controls 
the desired input/output operation in its en- 
tirety; thus, the CPM time required to initiate 
an I/O operation is only that needed to con- 
struct a request, queue it in the MSU, and in- 
terrupt the IOM. 



BASIC IOM CONFIGURATION 

As illustrated in figure IV-1-1, the IOM con- 
sists of six major subsections. Each subsection 
is totally independent of the other subsections, 
and operates asynchronously with them. 



CONTROL WORD FLOW 

All control word flow between main memory 
and up to 255 system peripherals is via (1) an 
IOM subsection called the Memory Interface 
Unit (MIU), (2) an IOM control subsection 
called the Translator (XLATOR), and (3) one of 
four IOM subsections,, each of which is uni- 
quely buffered to match the class of data 
transfer assigned to it. The XLATOR subsec- 
tion routes control of a given job request to 
one of these subsections dependent upon data 
class (batch, high speed, data communications, 
or real-time interactive). 

DATA FLOW 

All data flow between main memory and the 
peripherals is via the appropriate data-trans- 
fer subsection and/or the MIU; the XLATOR 
is not involved and is free for control of addi- 
tional job requests. When a data transfer is 
complete, however, the XLATOR is given con- 
trol over job termination, and control flow to 
main memory is via the appropriate data- 
transfer subsection, the XLATOR, and the 
MIU. 
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Figure IV-1-1. IOM Basic Block Diagram 
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IOM/PERIPHERAL INTERFACE CONFIGURATION 

Figure IV-1-2 illustrates typical peripheral 
devices which may be assigned to each data- 
transfer class; also illustrated are the data- 
transfer subsection names which are hence- 
forth referred to. The following is a brief de- 
scription of the interface capability of each 
subsection, and its physical relationship to 
typical peripheral equipment. The descriptions 
are presented in reference to figure IV-1-3, 
which illustrates the interface capability pro- 
vided when two maximum-configuration In- 
put/Output Modules and appropriate ex- 
changes are used. It should be noted that a 
maximum of 28 peripheral controllers (exclud- 
ing DFO's and DCP's) may be connected to a 
single IOM. 

PERIPHERAL CONTROL INTERFACE (PCI) 

The PCI of a single IOM consists of either 
one or two interface sections, dependent upon 
user requirements. Each section has 10-chan- 
nel interface capability, for a total maximum 
capacity of 20 channels per IOM. 

The controls serviced by a PCI are housed in 
one or two peripheral control cabinets (PCC's). 
Each PCI/PCC cabinet services one IOM and 
has a 10-channel interface capability. Up to 
five of these channels can be assigned to large 
controllers, but the remaining channels must 
be assigned to small controllers. Table IV-1-1 
lists the various controllers which may be 
housed in PCI/PCC cabinets. 

Any combination of small controls may be 
housed in the PCI/PCC cabinet. The large con- 
trols (SLC and MTC) may be connected to the 
peripheral units directly, or, in the case of the 
MTC only, via exchanges. Any unused chan- 
nels in the PCC cabinet are left empty. 

The PCI multiplexes all 20 channels by gen- 
erating overlapping 1-micro-second data-serv- 
ice cycles and by use of "windows" in a self- 
contained local memory. In the typical config- 
uration illustrated in figure IV-1-3, the use of 
two IOMs and appropriate exchanges (4X16) 
allows access by either IOM of 64 magnetic 
tape units. IOM number 1 is illustrated as 
having access to an additional non-exchange 
magnetic tape unit, and both IOM's are illus- 
trated as having access to SPO units via Sin- 
gle Line Controls (SLC). 

DISK FILE INTERFACE (DFI) 

The DFI of a single IOM consists of either 
one or two interface sections, dependent upon 
user requirements. Each section has an inter- 
face capability of four channels, for a total 
disk-file-channel capability of eight channels 
per IOM. 



Each DFI four-channel section services a 
single DFI/PCC cabinet. This cabinet contains 
only large channels (four maximum), which 
are dedicated to either disk files or disk packs. 
The channels may be connected to the periph- 
erals either directly or via exchanges. In the 
typical configuration illustrated in figure IV-1- 
3, the use of two maximum DFI-configuration 
IOMs (eight channels per IOM, four each disk 
file and disk pack) and appropriate exchanges 
(2X20 for disk file, 2X16 for disk pack) allows 
access by either IOM of 80 disk file electronics 
units (400 disk file storage units) and 64 disk 
packs. Table IV-1-2 lists the controllers which 
may be housed in the DFI/PCC cabinet. 

SCAN INTERFACE (SCI) 

The SCI consists of two sections: a DFO scan 
interface and a DCP scan interface. The DFO 
scan interface provides scan-in and scan-out 
control for up to four DFO's via a scan bus. If 
a second IOM is used, the DFO scan bus is 
shared by the two IOM's (see figure IV-1-3). 

The DCP scan interface provides scan-out 
control only, and may communicate with up to 
four DCP's via a scan bus. The SCI is not used 
for DCP scan-in functions, which are initiated 
by the DCP. For these functions, the DCP com- 
municates with main memory directly via the 
MIU. The DCP scan bus is not shared by a sec- 
ond IOM. 

DATA COMMUNICATIONS PROCESSOR INTERFACE 
(DCI) 

The DCI provides the data and control inter- 
face for IOM-initiated scan-out operations, and 
the data interface only for DCP-initiated scan- 
in operations. Interface is provided in each 
IOM for up to four DCP's. As illustrated in fig- 
ure IV-1-3, the use of two IOM's in a system 
allows interface with eight DCP's. 

IOM/MAIN AND IOM/CPM INTERFACE 
CONFIGURATIONS 

Figure IV-1-4 illustrates a typical interface 
configuration between the IOM's, MCM's, and 
CPM's of a typical system. The following is a 
brief description of the interface capability of 
the IOM/MIU subsection with main memory 
and the IOM/XLATOR subsection with system 
CPM's. 



IOM/MCM INTERFACE 

As illustrated in figure IV-1-4, the MIU con- 
tains eight interface areas. Each interface 
area is dedicated to a distinct Memory Control 
Module (MCM), and is connected to it via a 
unique memory bus. The bussed IOM/MCM in- 
terface is referred to as a memory/user pair. 
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Figure IV-1-2. Typical Data-Transfer Classifications and Related IOM Subsections 
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Figure IV-1-3. Typical lOM/Peripheral Configuration 



Table IV-1-1. PCI/PCC Channels 



Peripheral Controls 



ize 


Model 


Type 


L 


B 7381-11 


18/36 KB, NRZ, 9 Ch. 
MTC 


L 


B 7381-12 


36/72 KB, PE, 9 Ch. MTC 


L 


B 7381-14 


18/36 KB, NRZ, 9 Ch.., 
Dual MTC with 2x8 
Exchange 


S 


B 7240 with 


Printer Control Printer 




B 9943 


Memory 



S 


B 7120 and 
B 9926 


Paper Tape Reader 
Control and Input Code 
Translator 


S 


B 7220 and 
B 9928 


Paper Tape Punch and 
Output Code Translator 


L 


B 7381-15 


36/72 KB, PE, 9 Ch., Dual 
MTC with 2x8 Exch. 


L 


B 7381-16 


18/36 KB, 36/72 KB, NRZ/ 
PE, 9 HC, Dual MTC with 
2x8 Excm. 


L 


B 7391-3 


72 KC, 200/556/800 BPI, 7 
Ch MTC 


L 


B 7391-4 


96 KC, 200/556/800 BPI, 7 
Ch MTC 


L 


B 7393-1 


72 KB, 800 BPI, 9 Ch. 
MTC 


L 


B 7393-2 


144/240 KB, 1600 BPI, 9 
Ch. MTC 


L 


B 7393-3 


96 KB, 800 BPI, 9 Ch. 
MTC 


L 


B 7393-5 


320/400 KB, 1600 BPI, 9 
Ch. MTC 


L 




SINGLE LINE 
CONTROL-1 (SLC-1) 


L 




Single Line Control-2 
(SLC-2) 


S 


B 7110 


Card Reader Control 


S 


B 7212 and 
B 7610 


Card Punch Control and 
BCL-BCL Code Translator 



Peripheral Units 

18/36 KB, 9 Ch. NRZ Clusters (800 BPI, 2, 3, or 4 Station) 

36/72 KB, 9 Cu. PE Clusters (1600 BPI, 2, 3, or 4 Station) 
18/36 KB, 9 Ch., NRZ Clusters (800 BPI, 2, 3, or 4 Station) 

300/400 LPM, 120/132 Print Position Printers 

860 LPM, 120 Print Pos; 725 LPM, OCR "A" and "B" 
Numeric & Std; 1100 LPM, 120 Print Position; 900 LPM, 
OCR "A" and "B" Numeric and Std Printers 

Paper Tape Reader, 500-1000 CPS 

Paper Tape Punch, 100 CPS 

36/72 KB, 9 Ch. PE Clusters (1600 BPI, 2, 3, or 4 Station) 

18/36 KB, 9 Ch. NRZ/PE Clusters (800/1600 BPI, 2, 3, or 4 
Station; 36/72 KB, 9 Ch. NRZ/PE Clusters (800/1600 BPI, 2, 
3, or 4 Station) 

18/50/72 KC, 7 Ch. (200/556/800 BPI) MTU 

24/66/96 KC, 7 Ch. (200/556/700 BPI) MTU 

72 KB, 9 Ch., 800 BPI MTU 

144 KB, 9 Ch., 1600 BPI MTU 

96 KB, 9 Ch., 800 BPI MTU 

240 KB, 9 Ch., 1600 BPI, MTU 

Burroughs Terminal Computer TC500; Burroughs Input and 
Display Terminal B 9352 

Burroughs Terminal Computer TC500; Input and Display 
Terminal B 9352; Input and Display System B 9351 

800 and 1400 CPM Card Readers 

300 CPM Card Punch 



Model 


Peripheral Controls 




Type 


B 7877 


Disk File Control 




IV 


B 7380-1 


Single Dual-Drive 




Control, D:sk Pack 


B 7380-2 


Dual Dual Drive 




Control, Dsk Pack 


B 7383-1 


Single Dual-Drive 




Control, Disk Pack 


B 7383-2 


Dual Dual Drive 



Table IV-1-2. DFI/PCC Channels 

Peripheral Units 

IC-3 and IC-4 Disk Files 

Single Data Access, Dual Drive Disk Packs, 121 Megabyte 
Simultaneous Data Access, Dual Drive Disk Packs, 121 Megabyte 
Single Data Access, Dual Drive Disk Packs, 242 Megabyte 
Simultaneous Data Access, Dual Drive Disk Packs, 242 Megabyte 



Control, Disk Pack 
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Similarly the Central Processing Module 
(CPM) also contains eight MCM interface 
areas. Each CPM interface area is dedicated to 
a distinct MCM and is connected to it via a 
unique memory bus. The bussed CPM/MCM in- 
terface is also referred to as a memory/user 
pair. 

The interface capability of an MCM is eight 
memory busses, each of which is connected to 
one and only one IOM or CPM. Therefore, the 
maximum combined number of CPM's and 
IOM's which may be bussed to an MCM is lim- 
ited to eight. 

The maximum number of MCMs which may 
be contained in a B 7700 system is also limited 
to eight. This limitation is imposed by the 
eight MCM-dedicated interface areas of each 
IOM and CPM in the system. 

The typical memory-bus configuration illus- 
trated in figure IV-1-4 indicates the use of two 
IOM's, two CPM's, and two MCM's. This con- 
figuration provides a total of eight memory/ 
user pairs (MCM to users thru 3 and MCM1 
to users thru 3). The maximum number of 
Memory Storage Units (MSU) with which an 
MCM can communicate (four) is also illus- 
trated. Each of these MCM's can access 
262,144 words of memory (4 MSU's of 65,536 
words each). Each IOM or CPM, when con- 
nected as illustrated on figure IV-1-4, can 
therefore access 524,288 words of memory. 

IOM/CPM INTERFACE 

The interface between the IOM's and CPM's 
of a B 7700 system consists only of an inter- 
rupt bus. The XLATOR section of an IOM is 
informed by the CPM of job requests via the 
bus, and the XLATOR informs the CPM of 
non-channel-related IOM errors via the bus. In 
addition, the XLATOR uses the bus to inform 
the CPM of (1) I/O job completion when so re- 
quested by software, and (2) status change by 
a single-line control device. 

The interrupt bus is common to all IOM's 
and CPM's in a system, as is illustrated in fig- 
ure IV-1-4. 

IOM OPERATIONAL CHARACTERISTICS 

The IOM is designed to operate asynchro- 
nously with the CPM in the initiation, service, 
and termination of input/output transfers by 
use of a "job map" which is stored in level-1 
memory. The "job map" consists basically of 
five software-constructed elements which de- 
fine the job request, the peripheral device, and 
the IOM channel. 

In general the map elements inform the 
CPM of its IOM/Peripheral resources and their 
status. When necessary, the CPM alters the 



queued job requests of the "job map" to the 
extent of its interest and interrupts the IOM 
to request service. The IOM then accesses the 
"job map" to determine the input/output job 
and initiate it. Since the "job map" is a shared 
resource of the IOM and CPM, the IOM trans- 
fer times are masked by the continual process- 
ing and queueing of new requests by the CPM; 
thus maximum system throughput is attained 
with a minimum of CPM time. 

The IOM also manages path selection to the 
requested device (instead of the programmatic 
preselection of the path which is generally 
used). This path management eliminates the 
occurrence of situations whereby (1) the re- 
quested device is free, (2) the preselected path 
is not, and (3) an alternate path exists but can- 
not be used due to the programmatic preselec- 
tion. These situations generally require in- 
volvement of the CPM until the preselected 
path is free and the job is initiated, which ef- 
fectively reduces the parallelism of the CPM 
and IOM. Since the IOM manages the path se- 
lection in the B 7700 system, CPM involvement 
regarding job initiation ends when an inter- 
rupt is sent to the IOM. The IOM then initi- 
ates the job request when the requested de- 
vice and any path to that device is available. 

The design of the IOM incorporates exten- 
sive error-detection logic which monitors the 
flow of control words and data between the 
IOM and other main-frame modules, within 
the IOM module itself, and between the IOM 
module and peripheral devices. Particular em- 
phasis is placed upon preserving the integrity 
of all memory operations. In general, the er- 
ror-detection hardware consists of: parity 
check and generate circuitry; residue check 
circuitry; circuitry to detect illegal commands, 
conditions, and control states; and timeout cir- 
cuitry for memory transfers, scan bus 
operations, and internal IOM transfers. 

IOM JOB MAP 

The job map which an IOM accesses from 
main memory consists of the following five 
software-constructed elements: 

a. Home Address Words (HA) 

b. Unit Table Word (UT) 

c. I/O Queue (IOQ) 

d. I/O Control Block (IOCB) 

e. Status Queue (SQ) 

The following four level-1 addresses, which 
are loaded into the IOM XLATOR at initialize 
time, enable the IOM to service the job map: 

a. Home Address 

b. UT Base Address 

c. IOQ Header (IOQH) Address 

d. SQ Header (SQH) Address 
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Figure IV-1-4. Typical lOM/Main Memory and IOM/CPM Interface Configurations 
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By use of these stored addresses and the 
contents of previously-fetched map elements, 
job requests originally constructed by the 
CPM are reconstructed in the IOM and are 
serviced. 

The following basic description of each map 
element and the sequence in which the job 
map is serviced is presented in reference to 
figure IV-1-5. For detailed formats of all words 
discussed, refer to the appendix of IOM word 
HOME ADDRESS WORD 

The 51-bit home address word (HA word) is 
the first map element fetched by the IOM 
when interrupted by the CPM. It is fetched by 
use of the pre-loaded home address stored in 
the IOM XLATOR, and contains information 
which describes the basic command and, as ap- 
plicable, information which describes the de- 
vice or channel to be used. 

The command to be performed is defined by 
a code within the HA word, called the home 
code. In some instances further definition of 
the command is provided by additional bits of 
the HA word. Based on the command decoded, 
the logic of the IOM is conditioned to perform 
one of 20 possible control operations. The com- 
mands are described under the heading IOM 
COMMANDS later in this section. 

Only one of the 20 commands, the Start I/O 
command, requires immediate further access 
of other map elements; however, some scan- 
out commands require access of a second 51- 
bit HA word. The Start I/O command is the ba- 
sic command used to initiate service of new 
job requests, whereas the remaining com- 
mands are provided for either cold start/halt 
load, scan out control, configuration determin- 
ation, or diagnostic purposes. 

A home address (HA) word which contains a 
Start I/O home code also contains a unit desig- 
nate (UD) number. This number specifies the 
device to be used for the operation, and is part 
of the information needed to access the re- 
maining map elements. 

UNIT TABLE WORD 

The unit table (UT) word is the next map 
element fetched by the IOM in response of a 
Start I/O command. The fetch is performed by 
use of the UT address preloaded in the IOM 
XLATOR and the UD number derived from 
the HA word. The preloaded address serves as 
a locator for the unit table, and the UD num- 
ber serves as an index to a particular word of 
the unit table. 

The unit table consists of 256 words, which 
are numbered thru 255. Word is reserved 
for use as a fail UT word, and is accessed 
when an error occurs which cannot be associ- 
ated with a specific job request. In this in- 



stance, a special UD number (000), called a fail 
UD number, serves as an index to UT word 0. 
Each of the remaining 255 UT words is as- 
signed to a unique device, and contains infor- 
mation which defines the device and its as- 
signment within the system. 

The device-type and assignment information 
specifically indicates (1) whether the device is 
a disk-pack or a magnetic tape unit (2) if the 
device is a disk file, whether it is under DFO 
control, (3) whether the device is connected to 
an exchange, (4) the lowest IOM channel to 
which the device is connected. 

For a device connected to an exchange, the 
UT word contains additional information for 
use in IOM device/path management. The de- 
vices connected to an exchange are described 
by a linked list of UD numbers in the next 
unit on exchange (NUD) fields of their UT 
words. The number (modulo 4) of the last 
(highest) IOM channel on the exchange 
(LCEX) is also indicated. The description of 
the exchange is complete because (1) all IOM's 
on an exchange must use the same channels, 
(2) channels on an exchange must be 
consecutive, and (3) the largest exchanges 
serve a maximum of four channels. A bit 
(called the "job bit" or JB) is set if a job re- 
quest for an exchange device must be delayed 
because a path is not currently available. 

IOQ HEAD (IOQH) AND IOQ TAIL (IOQT) TABLES AND 
WORDS 

The I/O Queue (IOQ), which is constructed by 
the CPM in main memory, contains linked job 
requests (I/O Control Blocks) for each device 
of the system. The extent of the linked job re- 
quests for each device is defined by words 
which indicate the main memory addresses of 
the first and last of the requests. These words 
are called the I/O Queue Head (IOQH) word 
and the I/O Queue Tail (IOQT) word, respec- 
tively. 

The IOQH words for all devices (255 words) 
are stored in a table called the I/O Queue 
Head table; similarly, the IOQT words for the 
devices (also of 256 words) are stored in a table 
called the IOQT table, which immediately fol- 
lows lows the IOQH table in memory. 

The IOQH and IOQT tables contain one spe- 
cial word each (word 0) which is reserved for 
use by the IOM to report errors that cannot be 
associated with a specific job request. These 
words are pointers to a list of the fail I/O Con- 
trol Blocks (fail IOCB's) reserved for failure- 
reporting by the IOM's of the system (later de- 
scribed). 

The IOQT table is the element accessed by 
the CPM to queue additional requests for a de- 
vice. The IOM also accesses this element when 
a sidelink operation to another device is 
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Figure IV-1-5. IOM Job Map 



specified. This access is required so that the si- 
delink operation indicated in the job-request 
queue of one device may be linked to the 
queue of job requests for the device desig- 
nated for the sidelink operation. The IOQT 
word for the sidelink device is altered to re- 
flect the main memory address of the sidelink 
job, which becomes the last job queued. 

The IOQH table is the element accessed by 
the IOM in order to service job requests. The 
IOQH word for a device indicates the main 
memory address of the first job request for 
that device. Memory addresses of additional 
jobs for the device are indicated by the next 
link (NL) word in each job request, thus 
linking all job requests for a given device. 

As is indicated in figure IV-1-4, the last job 
request for a device is recognized by the IOM 
when the next link field of a request is found 
to contain zeroes (null). 

The IOQH word is fetched by use of (1) the 
IOQH table base address (stored in the XLA- 
TOR), and (2) the UD number (derived from 
the previously-fetched HA word). The UD 
number indicates which device is to be initi- 
ated, and therefore which IOQH word of the 
IOQH table should be fetched. The UD number 
is thus an index to the IOQH table. 

When a non-request-related error is detected 
by the IOM and access to the fail IOQH word 
(word 0) is required, the word is fetched by use 
of the fail UD number (000) and the IOQH 
base address. The memory address of the first 
available fail IOCB, which is contained in the 
fail IOQH word, is used to fetch the fail IOCB. 
The NL field contained in the fetched fail 
IOCB is then used to update the memory ad- 
dress of the fail IOQH word, so that if a sec- 
ond failure is detected, the next fail IOCB of 
the queue of fail IOCB's can be accessed. The 
fail IOQT word, which defines the last IOCB in 
the queue of ten fail IOCB's, is used only by 
software; it is not accessed by the IOM. 

When a sidelink operation requires a fetch 
of the IOQT word for a device, 256 is added to 
the IOQH word address (the IOQT-word ad- 
dress for a device designated for a sidelink op- 
eration equals the IOQH table base address 
plus the UD number of the device plus 256). 

I/O CONTROL BLOCKS 

The job requests for each device are stored 
in map elements called I/O Control Blocks 
Each I/O Control Block (IOCB) contains words 
which are fetched sequentially starting with 
the memory address obtained from either (1) 
the IOQH word if the job request is the first 
for the device, (2) the next link (NL) field of 
the job request (IOCB) in process if the job is 
other than the first for that device, or (3) the 
side link field of the job request (IOCB) in 



process, if a sidelink (SL) to another device is 
indicated. The six IOCB words fetched by the 
IOM are as follows: 

a. Next Link (NL) Word 

b. Side Link (SL) Word 

c. Buffer Descriptor (BD) Word 

d. I/O Control Word (IOCW) 

e. Channel Designate Level (CDL) Word 

f. Result Descriptor (RD) Word 

As previously indicated, the NL word con- 
tains the address of the next IOCB for a de- 
vice, and is the means whereby job requests 
for a device are linked within the IOQ. When 
this word contains all zeroes (null), it indicates 
the request being serviced is the last currently 
enqueued for the device. 

The SL word is used to indicate that a side- 
link operation (the service of a job request by 
a device other than that presently being serv- 
iced, without intervention by the CPM) is re- 
quired. The SL word contains the memory ad- 
dress of the sidelink job (IOCB), which is 
started immediately if no other jobs are 
queued for the designated sidelink device. If 
other jobs are queued for the device, the side- 
link job is linked to the queue of job requests 
by insertion of the sidelink memory address in 
both the IOQT word for the sidelink device 
and the NL field of the last IOCB previously 
queued for that device. 

The BD word contains the address of the 
first data location in memory, and the length 
of the memory area in words. 

The IOCW contains the control information 
necessary to perform the input/output 
operation, such as read or write, whether code 
translation is necessary, backward/forward 
(tape), frame length (6 or 8 bit), etc. The con- 
tents of the IOCW and the BD word are used 
to format the first job word sent to the se- 
lected IOM channel. 

The CDL word is used to format the second 
job word sent to the selected IOM channel. 
This word generally contains information such 
as the OP code, the device number, the device 
variant, and for disk, the segment address. 

The RD word is used for storage of the ter- 
mination status of each request. The RD word 
is built by the IOM, which then links the ter- 
minated request (terminated IOCB) into the 
status queue. 

FAIL I/O CONTROL BLOCKS 

A queue of special IOCB's, which are not re- 
lated to job requests, is also built in memory. 
These IOCB's, which are called fail IOCB's, 
are used by the IOM's of the system to report- 
ing errors which cannot be associated with a 
specific request. The fail IOCB's contain the 
same six words as job-request IOCB's; how- 
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ever, only the next link word and the result 
descriptor word have significance. 

The result descriptor word is used for stor- 
age of a fail result descriptor. The IOM builds 
the fail result descriptor, inserts it in the fail 
IOCB RD word, and links the fail IOCB into 
the status queue. 

STATUS QUEUE 

The Status Queue (SQ) is a queue of (1) all 
job-request related IOCB's which have been 
serviced and terminated, and (2) any fail 
IOCB's which have been generated by the 
IOM. When job-request IOCB's are terminated 
(or fail IOCB's are generated) and the neces- 
sary result descriptor information has been 
stored in the RD word of the IOCB, the IOCB 
is unlinked from the job IOQ (or fail IOQ) and 
is linked into the status queue. The linked 
IOCB's in the status queue represent a mix of 
terminated IOCB's for all devices and any fail 
IOCB's. 

The SQ for the system consists of queues of 
linked IOCB's, one queue for each IOM on the 
system. The number of queues is dependent on 
the number of IOM's in the system. 

The mechanism by means of which the sta- 
tus queue is accessed is the SQH address 
stored in the IOM XLATOR at initialize time. 
This address is unique for each IOM used, and 
serves as a pointer to a word in memory which 
defines the queue of linked IOCB's associated 
with a particular IOM. This word is called the 
status queue header (SQH) word. 

When a request is terminated, the SQ ad- 
dress of an IOM is used to fetch the SQH 
word, which contains the following basic infor- 
mation: 

a. Null (empty) state of SQ 

b. Head field 

c. Tail field 

d. Status-Change-Vector bit 

e. CPM-Interrupt bit 

f. CPM Number 

The null state of the SQ is checked to deter- 
mine whether it contains any terminated 
IOCB's. If the SQ is null (empty), no linkage of 
the current terminated IOCB to previously- 
terminated IOCB's in the SQ is required. Con- 
versely, if the SQ is not null (contains one or 
more IOCB's or fail IOCB's), the current ter- 
minated IOCB must be linked to the queue of 
terminated IOCB's in the SQ. 

The head field of the SQH word contains the 
base address of the first terminated IOCB of 
the SQ. The tail field of the SQH contains the 
base address of the last terminated IOCB of 
the SQ, except when the SQ is null or contains 
only one terminated IOCB. If the SQ is null 
the tail field is not used; if the SQ contains 
only one IOCB, the tail field contains the same 
address as the head field. 



A terminated IOCB is linked to previously 
terminated IOCB's stored in the SQ by insert- 
ing its base address in the next link (NL) word 
of the terminated IOCB indicated by the SQH 
tail field. The address in the tail field of the 
SQH is then replaced with the base address of 
the currently-terminated IOCB, so that link 
capability is present when another request is 
terminated. 

If the CPM interrupt bit is on in the SQH 
word, or the interrupt bit is on in the NL word 
of a terminated IOCB, a channel interrupt is 
sent to the CPM specified in SQH when the 
terminated IOCB is linked into SQ. An IOM er- 
ror interrupt is always sent to the designated 
CPM when a fail IOCB is linked into the SQ. 

When an SPO or a DCP requests an input 
operation, the status-change vector bit in SQH 
is set; and a channel interrupt is always sent 
to designated CPM. 

IOM HOME (HA) COMMANDS 

There are 20 home commands which the 
IOM can be directed to perform. When the 
IOM receives an interrupt from the CPM, it in- 
dicates that a home command has been con- 
structed by the CPM and placed in memory. 
The home address stored in the IOM is then 
used to fetch the HA word. A code within HA 
word 1, which is called the Home Code, is then 
decoded to determine which command or com- 
mand group is to be performed. 

Table IV-1-3 lists the valid home codes, and 
the commands and/or command groups defined 

Table IV-1-3. IOM HA Operations and 
Corresponding Home Codes 



Home 


IOM Operation 


Code 




0000 


Illegal 


0001 


Start I/O 


0010 


Set Channel Busy/S3et Channel 




Reserved 


0011 


Reset Channel Busy/Reset 




Channel Reserved 


0100 


Load Home Address 


0101 


Load Unit Table Address 


0110 


Load IOQ Head Table Address 


0111 


Load SQ Header Address 


1000 


DFO/DCP Scan-out Commands: 




DFO: 




Clear the Stack 




Store Control Word 




Request 




DCP: 




Initialize 




Halt 




Set Attention 


1001 


DFO Scan-In Operations: 




Queued Control Word 




Top of Stack 




Report 


1010 


Synchronous I/O 


1011 


Interrogate Peripheral Status 


1100 


Inhibit IOM 


1101 


Activate IOM 


1110 


Load DFO Flags 


1111 


Illegal 
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by them. As indicated, scan commands are de- 
fined by the home code as only scan-in or scan- 
out groups; determination of type of scan-in or 
scan-out, and whether DFO or DCP, is defined 
by other portions of HA word 1. Similarly, 
channel busy/channel reserved commands are 
resolved by other portions of HA word 1. HA 
word 2 is not used for all commands; when 
used, it contains information to further define 
the command. 

The following brief command descriptions 
are presented in reference to figure IV-1-6, 
which depicts the basic contents of the HA 
words for each command. Detailed formats of 
the HA word for each command are given in 
the appendix of IOM word formats. 

START I/O (HOME CODE 0001) 

The Start I/O command is the basic com- 
mand used to initiate input/output servicing of 
a new job request for a device. The device is 
defined by a unit designate number contained 
in bits 28 thru 35 of HA word 1, HA word 2 is 
not used. This command need only be given 
once in order to service all queued requests for 
the designated device. 

SET CHANNEL BUSY/SET CHANNEL 
RESERVED (HOME CODE 0010) 

Home code 0010 may represent one of two 
commands, dependent upon the state of bit 39 
of HA word 1. If bit 39 is a "0", the Set Chan- 
nel Busy command has been received; if bit 39 
is a "1", the Set Channel Reserved command 
has been received. Both commands are for ex- 
change channels; the channel number is de- 
fined by bits 23 thru 27 of HA word 1. HA 
word 2 is not used. 

The Set Channel Busy and Set Channel Re- 
served command are used primarily for diag- 
nostic purposes. A start I/O command for an 
UD, which has the reserved channel bit (RC) 
set in its UT word, must use a channel that 
has been set to reserved; otherwise, a reserved 
channel will not be used. An I/O operation can 
not use a channel that has been set to busy. 
Once either command has been received, the 
specified channel remains busy (or reserved) 
until a counter command is received. 

RESET CHANNEL BUSY/RESET CHANNEL 
RESERVED (HOME CODE 0011) 

Home code 0011 may also represent one of 
two commands, dependent upon the state of 
bit 39 of the HA word ("0" defines the Reset 
Channel Busy command; "1" defines the Reset 
Channel Reserved command). These com- 



mands are the counter commands to the Set 
Channel Busy/Set Channel Reserved com- 
mand. 

LOAD ADDRESS COMMANDS 

Load home address (home code 0100); load 
unit table address (home code 0101); load IOQ 
head table address (home code 0110); load SQ 
header address (0111). 

The commands are normally used to load 
fixed addresses into the IOM XLATOR at 
initialize time; however, they may also be used 
to establish new base addresses at any time 
after initialization. The address to be loaded 
by each command is contained in bits thru 19 
of HA word 1; HA word 2 is not used. 

DFO/DCP SCAN-OUT COMMANDS (HOME 
CODE 1000) 

Home Code 1000 specifies a scan-out com- 
mand for either a DFO or a DCP; the specific 
device for which the scan-out command is in- 
tended, as well as the specific type of scan-out 
command, is defined by other bits of HA word 
1. 

Whether the scan-out command is for a DFO 
or a DCP is dependent upon bits 19 thru 16 of 
HA word 1. A bit configuration of 1001 indi- 
cates the command is for a DFO, whereas a bit 
configuration of 1100 indicates the command is 
for a DCP. 

DFO SCAN-OUT COMMANDS 

There are two specific scan-out commands 
for DFO's. The command type is determined 
by the configuration of bits 4 and 5 of HA 
word 1 as follows: 

a. Bit 4 = 0, bit 5 = 1: Clear the Stack 

b. Bit 4 = 1, bit 5 = 0: Store Control Word 
Request 

The Clear the Stack Command is used to 
erase the DFO queuer stack and to reset any 
DFO error flip-flop previously set. The unit 
number of a Disk File Electronics Unit 
(DFEU) is contained in bits 8 thru 15 of HA 
word 1. This unit number is used with bit 7 
(the exchange select bit) to define either the 
DFO with which the DFEU is directly con- 
nected or the DFO with which the DFEU is in- 
directly connected. HA word 2 is not used for 
the Clear the Stack command. 

The Store Control Word Request command is 
used to request storage of a control word in 
the DFO queuer stack. The DFO is defined by 
bit 7 and bits 8 thru 15 of HA word 1, as de- 
scribed for the Clear the Stack command. A 
fetch of HA word 2 is required to implement 
this command. Bits 28 thru 47 of HA word 2 
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WORD 1 FORMAT 



TAG 



HOME 
CODE 



TAG 



51 50 4847 



43 4039 



35 



2827 



23 



19 



51 



ILLEGAL 


0000 












START I/O 


000 1 




UNIT DESIG 


SETCHANNEL BUSY 
RELEASE CHANNEL 


00 10 
10 




1 






CH. NO. 
CH. NO. 


RESET CHANNEL BUSY 
RESERVE CHANNEL 


11 
0011 




1 






CH. NO. 

CH. NO. 


LOAD H. A. 
LOAD U. T. 
LOAD Q. H. 

load s. a 


100 
10 1 
0110 
111 










HOME ADDRESS 
UNIT TABLE ADDRESS 
QUEUE HEAD TABLE ADDRESS 
STATUS QUEUE HEADER ADDRESS 



43 



40 



19 



16 15 



876543 1 



SCAN OUT DFO - CLEAR STACK 
SCAN OUT DFO - STORE CW REQST. 


1000 










10 1 

100 1 


UNIT NO. 
UNIT NO. 


P 

P 


1 
1 




- 


SCAN OUT DCP-INITIALIZE 

SCAN OUT DCP-HALT 

SCAN OUT DCP-SET ATTENTION 


10 00 










110 
1100 
110 




000 
01 
1 


DCP 
NO. 

DCP 
NO. 

DCP 

M Q 




— 


SCAN IN DFO-QUEUEDCW 
SCAN IN DF^^T P '" lC ^T A *~K 
SCAN IN DFO-REPORT 


100 1 










100 1 
100 1 


UNIT NO. 

WIM1 1 IVUi 


P 


1 

1 u 

1 1 







43 



4039 36 



27 



23 



19 



SYNCHRONOUS I/O 


10 10 






CH. NO. 




IOCB ADDRESS 




INTERROGATE PERIPHERAL STATUS 


10 11 






N ! 




INHIBIT IOM 


1100 






2 9 




ACTIVATE IOM 


110 1 








LOAD DFO FLAGS 


1110 


FLAGS 




ILLEGAL 


1111 

















51 



47 



WORD 2 FORMAT 









47 
















28 






25 








n 








inrR anriBF?? 




niiK snniiFW 














INSTRUCTION BASE ADDRESS 




19 

47 40 26 7 












STATUS 
REPORT 




IOCB ADDRESS 










STATUS 
REPORT 




iOCB ADDRESS 










V 


PR 1 


V 


PR 2 


V 


SEC 1 


V 


SEC 2 


QSTK CAP 






47 42 37 32 27 22 








I STATUS BITS 

.. .i — - 


A 



SENT TO IOM 



RECEIVED FROM IOM 



47 



32 



1 



Figure IV-1-6. Home Address Commands 
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memory, and bits thru 25 contain the disk 
address to be used. 

DCP SCAN-OUT COMMANDS 

There are three specific scan-oat commands 
for the DCP; the command type is determined 
by bits 5, 6, and 7 of HA word 1 as follows: 

a. Bits 5, 6, and 7 = 0: Initialize 

b. Bits 5 = 0, bit 6 = 1, bit 7 = 0: Halt 

c. Bits 5 and 6 = 0, bit 7 = 1: Set Attention 
The DCP for which the command is intended 

is indicated by a DCP number contained in 
bits 1 thru 3 of HA word 1. 

The Initialize command requires access by 
the IOM of HA word 2, which contains an in- 
struction base address (bits thru 19). HA 
word 2 is not used for the Halt and Set Atten- 
tion commands. 

The Initialize and Halt commands cause 
psuedo fault interrupts to occur within the 
DCP. In the case of the Initialize command, 
the interrupt causes the 20-bit instruction 
base address to be loaded into the DCP 
scratch-pad memory. The interrupt generated 
by the Halt command stops DCP operations. In 
either case, stop actions which would normally 
occur within the DCP due to fault interrupt 
occurrence are inhibited. 

The Set Attention command is used to notify 
the DCP that attention to the B 7700 system is 
required. 

DFO SCAN-IN COMMANDS (HOME CODE 1001) 

Home code 1001 specifies that the command 
to be performed is one of three DFO scan-in 
commands. The specific command is defined by 
the configuration of bits 4 and 5 of HA word 
1 as follows: 

a. Bit 4 = 1, bit 5 = 0: Queued Control Word 

b. Bit 4 = 0, bit 5 = 1: Top of Stack 

c. Bit 4 = 1, bit 5 = 1: Report 

The desired DFO is addressed by use of a 
DFEU number and exchange-select bit as in 
DFO scan-out commands. This information 
however, is not used for the Report commands. 

HA word 2 is not accessed to further define 
command parameters. However, it is later 
used for storage of the scan-in word received 
via the scan information lines, and is the 
mechanism by means of which the CPM is no- 
tified of the location and status of the scan 
data. 

The Queued Control Word command is used 
to request an optimized control word from the 
queuer stack of the DFO. The Top of Stack 
command is used to request DFO transmission 
of the control word located at the top of the 
DFO queuer stack. 



The report command is used to request a re- 
port from the DFO, which defines the DFEU's 
connected to all DFO primary and secondary 
parts. The report is stored in HA word 2. Four 
fields in the report stored in HA word 2 are 
used to define the DFEU's which are con- 
nected to the four DFO ports (two primary and 
two secondary). Each field consists of (1) a bit 
(valid) which indicates whether an EU/DFO 
bus is connected to the port, and therefore 
whether the field is valid, and (2) four bits 
which represent the most significant bits of 
the unit number of the lowest-numbered 
DFEU connected to the port. A maximum of 
40 DFEU's may be connected to a DFO (20 di- 
rect and 20 indirect;). Since the DFO provides 
four ports, a maximum of 10 DFEU's are con- 
nected to a port, and the four bits are suffi- 
cient to define them. 

The report returned and stored in HA word 
2 also contains information which defines the 
capacity of the DFO queuer stack. The infor- 
mation is reported in bits 22 thru 27 of HA 
word 2. 

SYNCHRONOUS I/O COMMAND (HOME CODE 
1010) 

The Synchronous I/O command provides a 
means of servicing a single job request during 
initialization. Only HA word 1 of the job map, 
which contains the IOCB base address (bits 
thru 19), is accessed; no queue mechanisms are 
used. When the single job request is termi- 
nated, the result descriptor information is 
stored in HA word 5, and a channel interrupt 
is sent to the CPM. 

INTERROGATE PERIPHERAL STATUS 
COMMAND (HOME CODE 1011) 

The Interrogate Peripheral Status command 
is used to determine the ready status of all de- 
vices assigned to a particular status vector. 
The status vector to be interrogated is indi- 
cated by bits 9 thru 12 of HA word 1. 

HA word 2 is not accessed for command de- 
termination, but is later used for storage of 
the returned status information. The status 
information, which is returned in bits 1 thru 
32 of HA word 2, provides indication of the 
ready status of up to 32 devices on a vector. 
Bit of HA word 2 (ATTN) notifies the CPM 
that the status word has been returned. 

INHIBIT IOM COMMAND (HOME CODE 1100) 

The Inhibit IOM command is used to inhibit 
all automatic IOM functions, such as data- 
path management, DFO scan-in and scan-out 
functions, chaining of linked and side-linked 
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job requests and ringwalk. If linked job re- 
quests for ringwalk dtsvices are being serviced 
when the command is received, chaining stops 
after the IOCBs in progress on each channel 
are completed. 

The content of HA word 1 consists only of 
the home code; HA word 2 is not accessed. 

ACTIVATE IOM COMMAND (HOME CODE 1101) 

The Activate IOM command is used to re- 
store automatic functions of the IOM after the 
Inhibit IOM command has been given. The 
command consists only of the home code in HA 
word 1; HA word 2 is not used. 

LOAD DFO FLAGS COMMAND (HOME CODE 
1110) 

The Load DFO Flags command is used to 
mask out one or more DFO's connected to an 
IOM. The HA word in which the Load DFO 
Flags command is received contains four flag 
bits, one for each DFO which may be con- 
nected to an IOM. These bits (36 thru 39) are 
referred to as the DFO ON/OFF flags for DFO 
numbers thru 3, respectively. When an OFF 
flag (0) is detected, scan-in and scan-out 
operations with the associated DFO are inhi- 
bited. 

AUTOMATIC SERVICE OF DISK JOBS FOR 
UNITS UNDER DFO CONTROL 

In B 7700 disk file subsystems where the 
disk jobs are not optimized, the service of mul- 
tiple job requests for disk units on a common 
exchange involves an inherent delay between 
service of each job request. This delay is par- 
tially due to the manner in which the jobs 
must be linked under the queue of IOCB's for 
each Disk File Electronics Unit (EU); that is, 
without regard to the relationship of the disk 
starting address specified by each job request 
and the current disk position (relative to the 
head), since the current disk position is un- 
known. 

In B 7700 disk file subsystems where Disk 
File Optimizers are used, the inherent delay 
between the service of multiple job requests is 
reduced. The job requests are linked under the 
queues of IOCB's for the DFO's, rather than 
under the queues of IOCB's for the EU's as in 
a non-optimized system. Upon receipt of a 
Start I/O HA command, the UT word is 
fetched. If the DFO bit is set, the job requests 
are automatically scanned out to the DFO job 
stack when possible. The DFO's constantly 
monitor the disk addresses specified by the job 
requests in the stack and compare them with 
the current disk position relative to the head. 
This information is used to maintain a job- 
stack pointer which indicates the current opti- 
mum job request relative to disk/head position. 
This current optimum job request is referred 
to as a queued control word. 



The DFO's communicate with the IOM via a 
common scan bus and individual status lines. 
The status lines transfer information regard- 
ing the capability of the individual DFO's to 
receive job requests from the IOM over the 
scan bus. In addition, the status lines transfer 
levels which indicate the availability of 
queued control words which require service. 
The SCI section of the IOM scans these status 
lines to determine whether queued control 
words are available from any DFO. If the sta- 
tus lines of any DFO indicate the availability 
of queued control words, the SCI section of the 
IOM determines whether a disk channel is 
available on the exchange to which the DFO is 
connected. If so, a scan address word is for- 
matted by the Xlator and SCI sections of the 
IOM, and is then sent over the scan bus to all 
DFO's. The contents of the scan address word 
sent over the scan bus identify the exchange 
and the DFO on that exchange which has indi- 
cated availability of queued control words. The 
scan address word on the scan bus is recog- 
nized only by the identified DFO, and there- 
fore is, in essence, an acknowledge to that 
DFO. 



In response to the scan address word re- 
ceived, the identified DFO transfers a scan in- 
formation word over the scan bus to the IOM. 
This word contains a complete memory link 
address, which is used by the IOM to further 
access the IOM job map for the identified job. 
The map access performed provides informa- 
tion which identifies the EU which is to con- 
trol the disk job, whether that EU is available, 
and whether the previously-available disk 
channel is still available. If all conditions are 
met, the job is initiated and data are trans- 
ferred between the DFI section of the IOM 
and the specified EU. Upon completion of the 
data transfer, the disk job is terminated in the 
normal manner. If the identified EU is not 
available or if the disk channel is not avail- 
able, the disk job is relinked under the queue 
of IOCB's for the DFO. It is then later trans- 
ferred again to that DFO for reoptimizing and 
another attempt at job initialization. 



AUTOMATIC DISK-PACK OPERATION 

The IOM has provisions to automatically re- 
initiate a type 225 Disk Pack Unit after the 
unit has completed a seek operation. This type 
of unit, when issued a conditional I/O com- 
mand requiring head positioning (seek), must 
be issued the same command after the seek 
has been completed in order to accomplish 
data transfer. The IOM performs this function 
by examining all device result descriptors re- 
ceived from Disk Pack units. 
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DATA TRANSLATION 

The PCI section of the IOM has the 
capability of translating data from one repre- 
sentation code to another during an I/O 
operation. The data types actually encoun- 
tered are device dependent, and the transla- 
tion to be performed (if any) is determined for 
each individual job request by standard con- 
trol bits in the IOCW. The IOCW bits used to 
specify code translations are: 

Bit 46 - ASCII on for any translation having 
ASCII input or output. 

Bit 44 - READ - (READ = 1, WRITE = 0) 

Bit 42 - TRANSLATE 

Bit 41 - FRAME LENGTH (8 bit characters 
= 1, 6 bit characters = 0) 

All possible combinations of these code bits 
are listed in detail in table IV-1-4 and the spe- 
cific translation codes used by software for 
each peripheral devices are given in table IV- 
1-5, 

EBCDIC-BCL EXCEPTIONS 

Bi-directional translation of corresponding 
EBCDIC graphics to/from corresponding BCL 
graphics are provided with the following ex- 
ceptions: 

a. EBCDIC to BCL (output translator) 
EBCDIC BCL 

PZ + 

MZ x (times) 

Corresponding Corresponding graphic 

graphics 

Non-corresponding (See Note) 
graphics 

NOTE: 

The following graphics are printed depend- 
ent upon whether the printer is equipped for 
EBCDIC or BCL: 



om uci oioi ono noi oioo mi 



EBCDIC Printer (Apostrophe) (Logical not) (Underscore) (Vertical bar) 



BCL Printer 



b. BCL to EBCDIC translator (input trans- 
lator) 



BCL 

X (times) 
Corresponding 

graphics 



EBCDIC 

MZ 

Corresponding 

graphics 



IOM-GENERATED INTERRUPTS 

The IOM generates the following two inter- 
rupts and sends them over individual lines to 
each central processor: 

1. Channel Interrupt 

2. IOM Error Interrupt 

An IOM interrupts exactly one processor; 
the CPM to be interrupted is determined by 
the CPM field (bits 44-42) of SQH. 

There are three conditions under which the 
IOM generates an interrupt to a CPM: 

a. IO Complete - On job request termination 
a channel interrupt is generated when bit 40 
of the IOCB NL word is set or when bit 40 of 
the Status Queue Header is set. These bits are 
set by software; bit 40 in SQH is reset by the 
IOM after an interrupt is generated. Unless 
requested by software, an interrupt is not set 
for "exception conditions" (peripheral parity 
error, end of tape, etc.). The only action taken 
for an "exception condition" is that the next 
request job, if there is more than one request 
job queued, is not started and bit of the UT 
word is set. 



Table IV-1-4. General Translation Specification Codes 



44 42 



FL 
41 



Translation 



46 



Write 6-bit bytes with no translation 

(Illegal Code) 

Write 8-bit bytes with no translation 

Write EBCDIC from ASCII 

Write BCL External from BCL Internal 

Write BCL External from ASCII 

Write BCL External from EBCDIC 

Write ASCII from EBCDIC 

Read 6-bit bytes with no translation 

(Illegal Code) 

Read 8-bit bytes with no translation 

Read EBCDIC into ASCII 

Read BCL External into BCL Internal 

Read BCL External into ASCII (See Note 1) 

Read BCL External into EBCDIC 

Read ASCII into EBCDIC 

Note 1: 

In these combinations the frame length bit should be "1". However, due to encoding considerations, it is necessary 
to use this code and alter the FL decode to cover these cases. 
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b. Status Changes - When the "inquiry re- 
quest" line for a Single Line Control device 
changes from "off" to "on" state, or when a 
DCP requests CPM attention, the IOM sets the 
proper bit in its status change vector (status 
vector 8). If this is the first such change since 
the vector was last interrogated by software, 
the IOM sets bit 45 in SQH to request soft- 



ware to read the status change vector and 
generates a channel interrupt. (Bit 45 in SQH 
is reset by software.) 

c. IOM Errors - An IOM error interrupt is 
generated for any error not related to a specif- 
ic job request (for example, a memory parity 
error on the Home Address word). The gener- 
ated fail result descriptor is placed in a 
dummy IOCB from unit 0. 



Table IV-1-5. Translation Codes by Device 

CODE SPECIFIER 



Device 

Card Reader 



Card Punch 



Line Printer 



Train Printer 



P.T. Reader 



P.T. Punch 



7 TR. TAPE 



9 Tr. Tape 



SLC 

Disk Pack and 
(See Note 1) 

Note 1: 



Disk 



R 

44 

1 
1 
1 
1 
1 
1 



































1 
1 





1 

1 
1 



1 



T 

42 





1 

1 
1 




1 

1 

1 




1 
1 
1 





1 
1 
1 
1 





1 

1 
1 

1 




1 
1 
1 
1 




1 

1 
1 



1 



1 




1 











FL 
41 



1 
1 




1 



1 




1 
1 





1 



1 

1 




1 
1 



1 
1 




1 
1 



1 




1 

1 
1 





1 




1 
1 

1 
1 
1 
1 

1 
1 

1 

1 



Description 



Read binary data (6-bit to 6-bit) 
Read EBCDIC data (8-bit to 8-bit) 
EBCDIC into ASCII 
BCL External into BCL Internal 
BCL External into ASCII 
BCL External into EBCDIC 



Read 
Read 
Read 
Read 



Punch binary (6-bit to 6-bit) 

Punch EBCDIC (8-bit to 8-bit) 

Punch BCL External from BCL Internal 

Punch BCL External from ASCII 

Punch BCL External from EBCDIC 

Punch EBCDIC from ASCII 

Write BCL External (6-bit to 6-bit) 
Write BCL External from BCL Internal 
Write BCL External from ASCII 
Write BCL External from EBCDIC 

Write with no translation (6-bit to 6-bit) 
Write with no translation (8-bit to 8-bit) 
Write EBCDIC from ASCII 
Write BCL External from BCL Internal 
Write BCL External from ASCII 
Write BCL External from EBCDIC 
Write ASCII from EBCDIC 

Read binary (6-bit to 6-bit) 

Read EBCDIC or Read ASCM (8-bit to 8-bit) 

Read EBCDIC into ASCII 

Read BCL External into BCL Internal 

Read BCL External into ASCII 

Read BCL External into EBCDIC 

Read ASCII into EBCDIC 

Punch binary (6-bit to 6-bit) 

Punch EBCDIC or Punch ASCII (8-bit to 8-bit) 

Punch BCL External from BCL Internal 

Punch BCL External from ASCII 

Punch BCL External from EBCDIC 

Punch ASCII from EBCDIC 

Punch EBCDIC from ASCII 

Write with no translation (6-bit to 6-bit) 

Write BCL External from BCL Internal 

Write BCL External from ASCII 

Write BCL External from EBCDIC 

Read with no translation (6-bit to 6-bit) 

Read BCL External into BCL Internal 

Write with no translation (8-bit to 8-bit) 

Write ASCII from EBCDIC 

Write EBCDIC from ASCII 

Read with no translation (8-bit to 8-bit) 

Read EBCDIC into ASCII 

Read ASCII into EBCDIC 

Write EBCDIC or Write ASCII (8-bit to 8-bit) 
Read EBCDIC or Read ASCII (8-bit to 8-bit) 



The DFI section of the IOM has no hardware translation capabilities. 
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SECTION 2 



FUNCTIONAL OPERATION OF INPUT/OUTPUT MODULE 

SUBSECTIONS 



GENERAL 

This section contains a brief description of 
the operation of each of the IOM subsections 
described in section 1 of this chapter. For the 
formats of the words discussed, refer to the 
appendix of IOM word formats in this manual. 

FUNCTIONAL OPERATION OF TRANSLATOR 

The translator (figure IV-2-1) is a special- 
purpose processor capable of performing spe- 
cific hardwired microsequences. It is the mech- 
anism of the IOM that services I/O requests, 
generates the request descriptors required to 
initiate peripheral devices, and reports job ter- 
mination and failure status conditions to the 
Central Processor. The operation of the trans- 
lator is keyed to respond to certain declared 
flag conditions. 

JOB SERVICE INITIATION 

In response to an interrupt from the Central 
Processor, the IOM unlock-fetches the word in 
memory referenced by the 20-bit Home Ad- 
dress stored in the HA location of the lower 
stack. The HA-word control fields define the 
control codes and function details for the re- 
quest as described in Section 1 of this chapter. 
When the Start I/O command is decoded, the 
Unit Designate (UD) field of the Home Ad- 
dress word is loaded into the UD register (see 
figure IV-2-1). 

The UD field is added to the 20-bit Unit Ta- 
ble (UT) base address (stored in the UT loca- 
tion of the lower stack) to address and lock 
fetch from memory (write with flashback) the 
Unit Table word for the device to be started. 
For devices other than a DFO, the contents of 
the channel number identification field of the 
UT word are used to access the Active Chan- 
nel Stack (ACS). If the device is not connected 
to an exchange, and if the ACS and UT word 
busy bits are reset, the I/O Queue Head word 
(IOQ base address + UD) is fetched from mem- 
ory to obtain the base address of the 10 Con- 
trol Block (IOCB). 

Successive fetches are made of (1) the IOCB 
base address plus 2, to obtain the buffer de- 
scriptor, (2) the IOCB base address plus 3 to 
obtain the 10 control word (IOCW), and (3) the 
IOCB base address plus 4 to obtain the Chan- 



nel Designate Level (CDL) field. The buffer 
descriptor is comprised of two fields: base ad- 
dress information and buffer-length informa- 
tion. The 20-bit base address field is used to lo- 
cate the buffer in memory. 

The IOCW Standard Control Field (SCF) con- 
tains information useful to the data service 
sections such as read/write, translate, and for- 
mat bits. Information contained in the buffer 
descriptor, SCF from the IOCW, and CDL word 
of the IOCB is sent to the data service section 
for starting up the selected device. The Unit 
Designate number is stored in the ACS and 
the ACS busy bit is set. The Unit Table word 
busy bit is set, and the UT word stored in 
memory is unlocked. The HA word is unlocked 
and set to all zeros. Control is transferred to 
the initial state. 

If the device to be started is connected to an 
exchange and the busy bit of the base channel 
location in the ACS is set, the translator logic 
selects the next channel of the exchange and 
checks its busy bit. If a channel is available, 
information is fetched from memory and is 
sent to the data service section, to start the 
selected device. If all channels of the exchange 
are busy, the job bit (JB) in the Unit Table 
word is set, and the UT word is stored un- 
locked in memory. Control is transferred to 
the initial state. These conditions are summa- 
rized in table IV-2-1. 



JOB-SERVICE TERMINATION 

When a device either completes a service or 
is terminated as a result of an error condition, 
the data service unit causes the terminate bit 
to be set for that channel. The terminate bits 
are located in the Active Channel Stack (ACS) 
of the translator; one bit for each of the possi- 
ble 28 channels available. In response to a ter- 
minate bit being set, the translator reads the 
corresponding Unit Designate (UD) informa- 
tion from the ACS. This information is used 
along with the unit table base address to index 
and lock-fetch from level- 1 memory the UT 
word for the terminating device. The I/O 
Queue Head is then fetched to obtain the base 
address of the I/O Control Block (IOCB). The 
Result Descriptor (RD) information received 
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Figure IV-2-1. Translator Component Interface 



Table IV-2-1. Unit Table and Active Channel Coded Decisions 



Unit Table Word 



A.C. 
Stack 



B20 B38 B37 B36 CBF CTF CRF 
RC EX JB BZ 



M 


X 














M 


X 





1 


X 


X 


X 


X 


X 





X 


1 


X 


X 


X 


X 





X 


X 


1 


X 


X 


X 





X 


X 


X 


1 


X 


u 





X 


X 


X 


X 


u 


X 


*1 


1 





X 


1 


X 


X 


*1 


1 





1 


X 


X 


X 


1 








X 


1 


X 


X 


1 








1 


X 


X 


M 


1 


1 











M 


U 


1 


X 





X 


X 


u 



Decisions 

Start job; unlock UT; Set BZ (UT) 

Error; Set Initiate Busy Channel Error (IBE) in Fail Word 

Error; Set Initiate Busy Channel Error (IBE) in Fail Word 

Error; Set Initiate Busy Channel Error (IBE) in Fail Word 

Error; Set Initiate Busy Channel Error (IBE) in Fail Word 

Error; Set Initiate Busy Channel Error (IBE) in Fail Word 

Unlock UT; Go to initial state 

Unlock UT; Go to initial state 

Unlock UT; Set JB; Go to initial state 

Unlock UT; Set JB; Go to initial state 

Start job; Unlock UT; Set BZ, Res JB 

Unlock UT; Set JB, go to initial state 



X = State irrelevant 

M = States match 

U = States do not match 

EX = Exchange bit 

JB = Job to be done 

BZ = Job Busy 

RC = Use reserved channel only 

CBF = Chan Busy FF 

CTF = Chan Term FF 

CRF = Chan Reserved FF 

* = Applicable only when second IOM has set JB 



from the data service unit is then stored in 
the sixth word of the IOCB, and the IOCB is 
linked to the Status Queue (SQ). 

If this is the last request for this unit, the 
I/O Queue Head (IOQH) and I/O Queue Tail 
(IOQT) are nulled, and the UT word is stored 
unlocked, to complete the termination. If there 
are more requests, the address of the next 
IOCB is inserted in the 20-bit address field of 
the I/O Queue Head. Control is passed to the 
start section to initiate the request. If the ter- 
minating IOCB is the last request for this 
unit, and the unit is connected to an exchange, 
then control is passed to the ring-walk section 
and a search is made to find a request that is 
waiting to be initiated. 



EXCHANGE RING WALK 

The following action is taken when an ex- 
change unit terminates and there are no more 
requests queued for that particular unit. 

The Present Unit Designate (PUD) field 
from UT is saved in the S register. The Unit 
Designate (NUD) field in the UT word of the 
terminating device points to the next unit (de- 
vice) of the exchange. The UT word for this 
unit is fetched from level-1 memory and status 
of the busy and job bits is checked. If the unit 
is busy or there are no jobs waiting service, 
then the information in the Next Unit Desig- 
nate (NUD) field in the UT word is used to 
point to the next unit of the exchange. This 



process of looking for a request continues un- 
til either a request is found or the entire 
exchange has been walked (NUD=saved 
PUD). When a unit is found with a serviceable 
request waiting, the IOQH word for that unit 
is fetched from memory and the job is started. 

AUTOMATIC SERVICE OF DISK JOBS VIA DFO 
UNITS 

10 requests for disk units under control of a 
Disk File Optimizer (DFO) are entered in the 
10 Queue for the DFO rather than the 10 
Queue for the appropriate disk unit. The unit 
table word for the DFO has bit 39 (DFO) set. 
The start 10 operation for a DFO causes the 
unit table word to be lock-fetched from 
memory. If the DFO bit is set, the DFOQ flag 
is set in the IOM, the unit table word is writ- 
ten to memory and unlocked, and the transla- 
tor goes to an idle state. 

At any time while in idle state, when the 
DFOQ flag is set, the DFO stack is not full, 
the DFO is on, the scan bus is not busy (SBY), 
and no jobs of a higher priority exist, an auto- 
matic DFO scan-out is initiated. The Queue 
Scan (QSN) flag is set and start mode is en- 
tered. The DFO unit table word is lock fetched 
from memory, and the DFO 10 Queue Header 
(IOQH) is read. If the IOQH is null, DFOQ and 
QSN are reset, the unit table word is written 
to memory and unlocked, and the translator 
returns to an idle state. If the OH is not null, 
scan mode is entered. The CDL word is fetched 
from IOQH +4. 
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Several fields are combined to form a scan- 
out word. The disk address and IOCB address 
fields form the scan data word, and the EUD 
field plus device type and function code fields 
form the scan address word. This information 
is placed on the scan bus. The UT word is writ- 
ten to memory and unlocked, and the Scan In 
Process (SIP) flag is set which inhibits the 
translator from initiating other jobs when in 
the idle state. The idle state is then entered. 
When SIP=1 and SBY=0, SIP is reset and 
scan mode is re-entered. 

The UT word is lock fetched from memory, 
the IOQH is read and the Next Link (NL) field 
is obtained from the IOCB; then NL is stored 
in the IOQH. If NL=0„ then the 10 Queue Tail 
(IOQT) is nulled and DFOQ is reset. The UT 
word is written to memory and unlocked, QSN 
is reset, and the translator returns to the idle 
state. 

A scan-in word is formed and placed on the 
scan bus when the translator is in the initial 
state, the scan bus is not busy, and a DFI 
channel is not busy (served by a DFO). When 
the Scan-In operation is completed, the trans- 
lator is notified. The 20 bit address field of the 
scan-in word is the base address of the IOCB 
for the next disk-file- EU to be started. The 
base address plus 4 is used to fetch the CDL 
information word. The EU Designate field of 
the CDL word and the UT Base are added, and 
the result is then used to fetch the UT word 
of the disk unit from memory. If the UT word 
busy-bit is zero, the Buffer Descriptor, CDL 
and IOCW are fetched as before and are sent 
to the DFI section to start the device. The 
base address is stored in the 10 Queue Head 
and is used for generating information during 
the terminate operation of the device. The 
busy-bit is set and the UT word is stored un- 
locked in memory and control is returned to 
the initial state. 

If the busy-bit is set in the disk UT word, 
the IOCB is linked into the tail of the DFO's 
10 Queue. 

DISK-PACK CONTROL 

The following actions are taken upon the re- 
ceipt and examination of result descriptors 
from Disk Pack units. 

When a result descriptor indicating "Seek 
Initiated" is received, the IOM will not de-link 
the IOCB or store the result descriptor as in 
normal terminate operations. Instead, the unit 
number of the Disk Pack which has begun a 
seek operation will be stored in a local stack. 
The contents of this stack are then used to 
monitor the ready lines of all Disk Pack Units 
which are currently seeking:. 



A "Seek Complete" will be detected when 
the ready line of a seeking Disk Pack returns 
to the true state. At this time, the Translator 
will perform a Start I/O for that Disk Pack 
unit. Since the original job was not de-linked 
from the job queue when the Disk Pack initi- 
ated its seek operation, the same job will be is- 
sued a second time, and the data transfer will 
occur. After this point, all IOM operations pro- 
ceed the same as for normal peripheral units. 
If the Disk Pack is issued a conditional I/O 
command which does not require head posi- 
tioning, data transfer occurs directly, and the 
Automatic Disk Pack functions of the IOM are 
not used. 

FAIL MODE OF OPERATION 

The fail mode is used to provide the IOM the 
capability of reporting errors that cannot be 
associated with a specific request. When an er- 
ror occurs, such as Scan Bus Error, Memory 
Error, Home Address Error, Illegal Command, 
etc., control is passed to the Fail Mode (FM) 
with appropriate error flags. 

A fail result descriptor is built in the fail 
register. This RD indicates (1) the operational 
mode when the error occurred, (2) a possible 
channel number (or memory address, depend- 
ing on the type of failure), and (3) error flags 
describing the type of error. 

A Fail Unit Designate number (Fail UD = 
zero) is used with the UT word to access a Fail 
UT word. Then the QH and Fail UD is used to 
access the fail I/O Queue Head. The fail result 
descriptor is placed in the Result Descriptor 
word of the I/O Control Block (IOCB). The Fail 
IOCB is then delinked from the queue of Fail 
CB's and linked to the Status Queue as on a 
normal termination. An IOM Error Interrupt 
is then sent by the IOM to the Central Proces- 
sor designated in the Status Queue Header. 

FUNCTIONAL OPERATION OF MIU 

The MIU (figure IV-2-2) performs all data 
and map-word transfers between the IOM and 
a maximum of 8 system Memory Control Mod- 
ules, and detects and reports memory error 
conditions to the requesting functional unit of 
the IOM (and to the translator when applica- 
ble). The MIU manages level-1 memory access 
requests by the functional units of the IOM on 
a preassigned priority basis. The access 
priority scheme for the functional units of the 
IOM is as follows: 

a. First Priority: Data Service requests 

b. Second priority: Data Communications 
Processor interface requests 

c. Third Priority: translator requests 
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When a functional unit of the IOM requires 
the services of the MIU for the purpose of per- 
forming a data transfer, it is required to raise 
its Access Request Line to the MIU and place 
a 26-bit Unit Control Word (UCW) on its UCW 
lines to the MIU. When the requesting unit 
has priority, the MIU loads the UCW into its 
control word register and performs one of the 
following operations: 

a. Single data word fetch 

b. N-length data word fetch 

c. Single word overwrite with flashback 

d. Single word protected write 

e. Single word protected write with 

f. N-length overwrite 

g. single word overwrite 
h. N-word protected write 

Upon determining the type of operation re- 
quested, the MIU constructs a Memory Con- 
trol Word (MCW) and transfers it to memory. 
Upon transferring the MCW to memory, the 
MIU is required to perform one of the 
operations listed below: 

a. If a Single Word Store operation was 
specified: The MIU raises its request lines to 
the specified Memory Control Module (MCM) 
in order to alternately transmit the MCW and 
the data word to be stored to the addressed 
MCM. The MIU continues to transmit the 
MCW, followed by the data word to be stored, 
until an acknowledge signal is received from 
the MCM. 

b. If a Multiple Word Store operation is 
specified: The MIU raises its request lines to 
the applicable MCM, and then sends the MCW 
to the MCM. When the MCM acknowledges re- 
ceipt of the MCW, the MIU commences the 
data transfer under the control of the Data 
Request signal. 

c. If a fetch operation is specified: The MIU 
raises its request lines and sends the MCW to 
the applicable MCM. When the MCM acknowl- 
edges receipt of the MCW, the MIU enables its 
memory-bus receiver circuits. Information 
from the MCM will now be accepted by the 
MIU. However, the MCM is required to trans- 
mit a Data Present Strobe pulse to the MIU to 
cause the information present on the memory 
bus to be transferred to and detected by the 
requesting IOM. The Data Present Strobe 
pulse is required for each word transferred 
from Memory to a requesting IOM. 

While performing a data transfer, the MIU 
is required to detect and/or report memory er- 
ror conditions. Memory errors are divided into 
two categories by the IOM: MlU-detected er- 
rors, and memory-detected errors. Memory er- 
rors cause termination of the memory request 
being processed, and the MIU transfers a 3-bit 



error code to the requesting section. The 
Translator reports these errors through the 
Fail Register. Data-service-section units re- 
turn these errors in the Result Descriptor. A 
decode of these three bits specifies whether 
the error is an MIU or memory-detected error. 
Errors detected and/or reported by the MIU 
and their associated 3-bit error reporting codes 
are listed in descending exclusive order as fol- 
lows: 

a. Store disparity (Oil) - This error condition 
is declared if a data transfer from an internal 
unit is received by the MIU with incorrect par- 
ity. The data with incorrect parity is trans- 
ferred to the memory. 

b. L1A Address Residue Error (010) - This 
error condition is declared if the MIU receives 
a UCW whose residue bits do not agree with 
its memory address field configuration (DCP 
words are not residue checked.) 

c. Memory Detected Error (111) - This error 
condition is declared when the addressed mem- 
ory module responds with a fail 1 (uncorrecta- 
ble error) indication to a requestor unit. 

d. No Access to Memory (101) - This error 
condition is declared if the MIU receives no re- 
sponse from the requestor memory module 
during a waiting period not to exceed 25 micro- 
second writing period. No response is defined 
as: 

1. Failure to receive, at the MIU, an ac- 
knowledged signal from an addressed 
memory module, or 

2. when incomplete data is transferred by 
an addressed memory module. 

e. Fetch Disparity (110) - This error condi- 
tion is declared if a fetch of data from memory 
is received by the MIU with incorrect parity. 

f. Memory Protect Error (100) - This error 
condition is declared when the addressed mem- 
ory module responds with a protect-error sig- 
nal during a memory protect store operation. 

g. Memory Detected Error (001) - This error 
condition is declared when the addressed mem- 
ory module responds with a fail 2 (1-bit cor- 
rected error) indication to a requestor unit. 
(This error condition does not cause termina- 
tion of the memory access operation.) 

FUNCTIONAL COMPONENTS OF THE MIU 

The MIU consists of nine functional compo- 
nents interfaced as illustrated in figure IV-2- 
2 and operated as described below: 

a. Priority Logic - This section is responsible 
for granting the services of the MIU to the 
highest priority requesting unit. 

b. Master Control Logic - This section con- 
tains the control logic necessary to execute all 
MIU operations, including the controls re- 
quired to complete receiver and driver paths. 
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Figure IV-2-2. Memory Interface Unit 



c. Residue Check Logic - This section is re- 
sponsible for checking and verifying the 
residue bits of the memory addresses trans- 
ferred from the translator and data service 
unity. 

d. Parity Check and Generate Logic - This 
section is required to generate odd parity for 
all words being transferred to memory, and to 
check for odd parity of all words being fetched 
from memory. 

e. Data Buffer Register - This is a 52-bit 
register and is used to buffer all data trans- 
fers between the requesting area of the IOM 
and the MIU. 

f. Memory Buffer Register - This is a 52-bit 
register and is used to buffer all input data to 
memory. 

g. LI A and Residue Logic - This section is 
responsible for constructing and routing the 
MCW to the data buffer register, as bits of the 
address. 

h. Receivers and Drivers - There are 8 dis- 
crete groups of receiver and driver circuits in 
the MIU, one group per Memory Control Mod- 
ule interface. The state of these groups is de- 
termined by master control; only one group is 
active at any one time. 

i. Limit Comparison Logic - This section is 
responsible for comparing the upper and lower 
address limits for the memory address: It is 
comprised of the limit comparison logic, encode 
logic, bus address register, and decode logic. It 
is the function of these logic areas to inform 
the requestor as to which MCM will be servic- 
ing the memory request and is accomplished 
by comparing the 6 most significant bits of the 
memory address to a known upper and lower 
limit for the answering MCM. 

FUNCTIONAL OPERATION OF PCI 

The PCI (figure IV-2-3) enables the IOM to 
interface with from one to twenty peripheral 
controllers (PCs), and coordinates data trans- 
fers between the PC's and the MIU as directed 
by the translator section of the IOM. The PCI 
interfaces with memory by one-word transfers 
via the MIU. Each PC requires a 1-micro- 
second service cycle to transfer data. By 
means of overlapping service cycles, and by 
use of local memory windows (a one-clock peri- 
od during which a particular operation may be 
performed if no higher priority operation is re- 
quired), it is possible to multiplex all twenty 
channels. 

There are four operational phases of the 
PCI: (1) channel initiation (2) channel service, 
(3) memory operations and (4) channel termi- 
nation. Each of these phases is described as 
follows. A general block diagram of the PCI is 
as shown in figure IV-2-3. 



CHANNEL INITIATION OPERATION 

This phase of PCI operation is controlled by 
Channel Designate Level (CDL) Control (re- 
ferred to as CC), and includes all functions re- 
quired of the PCI to start a device. The chan- 
nel initiation phase commences when the 
translator control logic places the first job de- 
scriptor word (DSU word) on the translator 
bus and raises the request line to the PCI. 
When a local memory window becomes avail- 
able, the CC strobes the DSU word into the lo- 
cal memory channel allocated to the device to 
be started, and lowers the PCI-available line 
to the translator. The translator control logic 
then lowers the request line and places the 
second job descriptor word (CDL word) onto 
the translator bus. 

When the next available local memory win- 
dow occurs, the CC strobes the CDL word into 
the appropriate location in local memory, 
strobes the channel number of the new re- 
quest into initiate queue stack (InQ), and 
raises the PCI-available line. The translator is 
thus informed that the entire request descrip- 
tor has been received and stored in local mem- 
ory. If no channel is currently being initiated, 
the CC selects the highest priority channel in 
the InQ, transfers this channel number to the 
CDL stack (CDS) which contains the request 
descriptor currently being initiated, and resets 
the INS bit for the selected channel. If no 
channel requires channel service, the CC 
checks the busy line of the channel. 

If a not busy condition is detected, the CC 
commences transfer of CDL characters to the 
appropriate PC at the rate of one character 
per available service cycle. If the selected 
channel is busy when initiation is commenced 
or if the selected channel becomes not busy 
during transmittal of CDL characters, the re- 
quest is terminated and appropriate result de- 
scriptor information is generated and trans- 
ferred to the translator (see channel termina- 
tion). After sending the correct number of 
CDL characters (4 for standard devices and 8 
for disk file devices), the CC raises the start 
channel bus line to the PC and resets the CDS, 
and the initiation operations are completed. 

CHANNEL SERVICE OPERATION 

After completion of the initiation phase, a 
channel is serviced upon demand at a rate de- 
pendent upon the type of peripheral device in- 
volved. The PC requests service by raising the 
access-request line (ARL) to the PCI. The PCI 
selects the highest priority channel requesting 
service and generates the appropriate access 
granted level (AGL). The presence of this sig- 
nal grants the next service cycle to the access- 
ed peripheral. The service cycle consists of two 
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Figure IV-2-3. Peripheral Control Interface 



T-time periods (Tl and T2) of 500 nanoseconds 
each; Tl is used for output to the PC. The 
AGL signal for the next service cycle is gener- 
ated during the previous service cycle's T2 
time period. 

Each data transfer is controlled by a chan- 
nel descriptor which has been generated from 
information contained in the DSU word of the 
job descriptor. 

If an error is detected at any time during 
channel service, the PCI generates the appro- 
priate result descriptor information for the 
translator (see channel termination) and ter- 
minates all operations on that channel. 

MEMORY OPERATION 

When the PCI determines that one 52-bit 
data word is required from or is ready to be 
sent to memory, the channel number selected 
for the transfer is placed in the Memory 
Queue (MQ). The MQ is a stack which contains 
the channel numbers of all channels requiring 
memory access. If no memory operation is cur- 
rently being executed, the PCI selects the 
highest priority job in the MQ, and transfers 
this number to the Memory Operation Stack 
(MOS). The PCI then resets the MQ bit for the 
selected channel, transfers the Unit Control 
Word to the Unit Control Word Register 
(UCWR), raises the PCI-memory-request line 
to the MIU, and, if necessary, transfers data 
into the Memory Transfer Area (MTA). 

Once access to the MIU is granted, the PCI 
strobe fetches data from the MTA, strobes the 
data to the appropriate data buffer in local 
memory, awaits the release signal which indi- 
cates that this memory request is completed, 
and then resets the MOS bit. The memory op- 
eration is thus completed. 

If the MIU detects an error at any time dur- 
ing this sequence, the error information is 
transferred to the PCI. The PCI then causes 
the request to be terminated, and an appropri- 
ate result descriptor is generated. 

CHANNEL TERMINATION OPERATION 

After completing the required data transfer, 
the PCI sends an I/O complete level to the PC. 
The PC then returns the result descriptor 
available level and returns a result descriptor. 
This result descriptor information, along with 
the present Channel Descriptor information, is 
used by the PCI to create the result descriptor 
word to bring about a normal termination. 

Abnormal-termination result descriptors can 
occur (1) during either channel initiation, 
channel service, or channel memory operations 
(when errors are detected by the PCI), (2) dur- 
ing channel memory operation (when errors 



are detected by either the MIU or the MCM, 
and (3) during channel initiation or channel 
service (when errors are detected by the PC). 
No matter what the source, all result descrip- 
tors are treated identically. 

Once the result descriptor has been generat- 
ed, it is stored in the local-memory location al- 
located to the channel to be terminated. The 
channel number of this request is strobed to 
the translator. Should the translator be un- 
able to accept the channel number, the PCI 
stores this channel information in the Termi- 
nation Queue (TMQ), which contains all the re- 
quests to be terminated. Whenever possible, 
the PCI selects the highest priority request 
from this stack, transmits the channel number 
to the translator, and resets the TMQ bit for 
the selected channel. 

The translator replies to the PCI termina- 
tion with a read-result-descriptor request, 
which causes the result word to be placed on 
the translator bus. This completes the termi- 
nation operation. 



FUNCTIONAL COMPONENTS OF THE PCI 

The PCI consists of nine functional compo- 
nents as illustrated in figure IV-2-3. These 
functional components are described as fol- 
lows: 

a. PCI Local Memory (PCLM) - Consists of 
twenty 126-bit word locations, one for each PC 
channel within the PCI. Is used to store the 
channel descriptors and data for the twenty 
channels. 

b. Descriptor Register (DR) - A 105-bit regis- 
ter which is loaded with the active channel de- 
scriptor. 

c. Shift Logic (SFT) - Consists of right and 
left shift logic to properly locate data within 
the data buffer of the channel descriptor. 

d. Byte Buffer (BB) - A 16-bit register 
which is loaded and unloaded (two 8-bit bytes 
at a time) during data transfers between the 
IOM and a PC. 

e. Code Translator (CDT) - Consists of the 
logic circuits necessary to perform EBCDIC to 
BCL - EXTERNAL or vice-versa, BCL-Exter- 
nal to BCL-Internal or vice-versa, ASCII to 
EBCDIC or vice-versa, and ASCII to BCL-Ex- 
ternal code translations or vice-versa. 

f. Stack Control - Contains stacks whose 
functions are described in functional 
operations. 

g. Control Section - Contains the CDL con- 
trol, channel service control, memory transfer 
control, and termination control which are de- 
scribed in preceding paragraphs. 
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h. Driver/Receiver Section - Consists of spe- 
cial drivers and receivers used for transmit- 
ting and receiving data and controls for the 
PC. 

i. Master Timing and Interface Control 
(STC) - Consists of logic to control the timing 
and interface sections and to provide control 
logic for the control panel. 

FUNCTIONAL OPERATION OF DFI 

The DFI (figure IV-2-4) enables an IOM to 
be interfaced with up to eight Disk File Con- 
trols (DFC). It consists of two independent, 
modular sections, each of which is capable of 
handling 4 data channels; each channel is in- 
terfaced to one DFC. 

Each section controls data transfers with 
the DFC's via a 16-bit data bus at a transfer 
rate of 2 eight-bit characters per transfer 
time. The transfer rate to memory is 2 words 
(2 x 48 bits) per transfer time. 

Each data channel comprises a four-word 
data-buffer area, called local data mode 
memory (LMD), and a 66-bit Channel-Descrip- 
tor local Memory (LMC). Upon command from 
the translator, the DFI initiates requests with 
its associated DFC's. During data transfer op- 
erations, the DFI communicates with the 
Memory Interface Unit (MIU) to obtain 
memory accesses. Upon request completion, 
the DFI notifies the translator of the termina- 
tion status and awaits re-initiation. 

The translator, upon receipt from memory of 
a disk file job, requests transmission of a job 
word to the DFI section assigned to handle 
that job. The selected DFI section loads the 
new request word into the proper channel-de- 
scriptor location in local memory and then re- 
leases the translator. 

The DFI section, according to priority, reads 
the channel descriptor of an active request. 
An active request may be in any one of 3 
separate modes. The exact mode is determined 
by the FAZ field in the channel descriptor. 
The three modes are (1) channel initiation, (2) 
channel service, and (3) channel termination. 

CHANNEL INITIATION OPERATION 

In the channel initiation mode, 48 bits of in- 
formation are sent to the addressed DFC. This 
transfer is accomplished as 6 transfers of 8- 
bits each. These 48 bits are contained in the 
second request word (job word 2) which was, 
upon receipt from the translator, stored in the 
LMD. The W/BP field of the channel descrip- 
tor points to the location in the LMD of the in- 
formation to be transferred to the DFC. 

A 16-bit byte, of which only the most 
significant 8 bits are valid, is loaded into the 



transfer register (TR) and is then sent to the 
DFC. After 6 such transfers, a Start Channel 
Bus (STCB) signal is sent to the DFC to indi- 
cate the end of the initiation phase, and the 
Phase (FAZ) field of the channel descriptor 
word is incremented by one. If the job word in- 
dicates an output operation, two fetches of two 
words each are requested from memory by 
way of the MIU during the initiation phase. 
The first of these two-word fetches is stored in 
word positions 00 and 01 of the LMD, and the 
second two-word fetch is stored in word posi- 
tions 10 and 11 of the LMD. 



CHANNEL SERVICE OPERATION 

The channel service operation, as indicated 
by the Phase (FAZ) field of the channel de- 
scriptor, consists of transferring 16-bit bytes 
of information to or from the DFC. If the DFC 
corresponding to the active channel has raised 
its access-request-level (ARL) line, the DFI 
responds by raising its access-granted-level 
(AGL) line and follows this by granting a one- 
microsecond service cycle. 

If the transfer is to be an input, data is ac- 
cepted during the first half of the one-micro- 
second service cycle and written into the Data 
Local Memory (LMD). If the transfer is to be 
an output, data is read from the LMD, placed 
in the transfer register (TR), and put on the 
data bus during the second half of the one-mi- 
crosecond service cycle. The location in the 
LMD of the 16-bit byte to be transferred is de- 
termined by the Word/Byte Position (W/BP) 
field of the channel descriptor. With each 16- 
bit byte transfer, the W/BP field is incre- 
mented by one. 



After two words of information have been 
transferred, memory request is again made by 
way of the MIU. The current memory address 
(CL1A) is sent along with certain control bits 
to the MIU, and if the request is for a read, 
two words are loaded from the LMD into the 
two-word buffer. If the request is for a write, 
two data words from memory will be loaded 
into the two-word buffer and then into the 
LMD. At this time the current memory ad- 
dress (CL1A) is compared to the final memory 
address (FL1A). If they are equal, the channel 
service phase is completed and the FAZ field 
is incremented by one; if they are unequal 
L1A is incremented by 2. The channel descrip- 
tor is restored into LMC and the next channel 
is serviced. 
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Figure IV-2-4. Disk File Interface 



CHANNEL TERMINATION OPERATION 

The channel termination operation is initi- 
ated when either of the following conditions 
occurs: 

a. Normal completion of transfer (CL1A = 
FL1A) 

b. Detection of an error by the DFI or the 
Disk File Control (DFC). 

If the DFI detects the condition CL1A = 
FL1A or detects an error, it sends an I/O-com- 
plete signal to the DFC. When the DFC detects 
either the I/O-complete signal or an error, it 
sends a result descriptor available (RDAV) sig- 
nal along with the next ARL signal. The DFI 
accepts the result descriptor and stores it in 
the FL1A field of the channel descriptor. The 
DFI sends the terminating channel number to 
the translator, and then awaits receipt of a 
Read- Result- Word request. When this request 
is received at the DFI, the result descriptor is 
sent to the translator and the channel termi- 
nation phase is completed. 

FUNCTIONAL COMPONENTS OF THE DFI 

Figure IV-2-4 illustrates the two DFI sec- 
tions and their respective interfaces with the 
Translator, MIU, and Peripheral Control 
Cabinets (PCC). The two DFI sections are iden- 
tical and contain the following components: 

a. Channel Descriptor Local Memory (LMC) 
- Provides storage for four 66-bit channel de- 
scriptors; one for each DFC channel. 

b. Descriptor Register (DR) - Used to store 
the descriptor of the active channel. The DR 
contents are used in conjunction with update 
logic to update the current memory address 
(CL1A) of the active job and to update various 
control bits. 

c. Update Logic - Used to update the CL1A 
by two words each time a memory access is re- 
quested. It is also used to update the Word/ 
Byte Position (W/BP) field, residue and phase 
(FAZ) fields, and various other control bits. 

d. Parity Check and Generate Logic - Gener- 
ates and stores odd parity for each descriptor 
to be stored in the LMC, and checks for odd 
parity on all descriptors read from the LMC. 

e. Data Local Memory (LMD) - Provides 
storage for sixteen 48-bit data word locations 
(two double-word locations for each of the 4 
DFC channels). The LMD acts as a buffer for 
data read from or written onto disk files. Also, 
during initiation of a request,, the LMD con- 
tains the 6 CDL characters (48 bits total) 
which are sent to the DFC. 

f. Two-word Buffer - Acts as a buffer for 
data being transferred between the LMD and 
the MIU. It contains storage for two 48-bit 
words. 



g. Transfer Register (TR) - A 16-bit register 
used to buffer all data transfers to or from the 
DFC. 

h. Parity Check, Generate, Accumulate, and 
Store - Checks and generates parity on data 
transferred from or to the DFC. When data is 
sent to the DFC, a parity bit is received from 
the MIU with each data word, and is stored in 
the accumulator. The parity bit setting of the 
accumulator is updated with each 16-bit trans- 
fer to the DFC, and is checked against the par- 
ity of the last such transfer. When data is re- 
ceived from the DFC, a parity bit is received 
with each data transfer and is stored in the 
accumulator. The parity bit setting is updated 
for each new 16-bit transfer, and a final set- 
ting is sent to the MIU for each new 48-bit 
data word. The MIU then checks parity on the 
full 48-bit word (three 16-bit transfers per 48- 
bit word). 

FUNCTIONAL OPERATION OF SCI 

The SCI (figure IV-2-5) contains the storage 
and controls required to provide a scan bus for 
communication with four DCP's and four 
DFO's. The scan bus to the four DFO's is 
shared between two IOMs. 

The translator initiates scan operations by 
transmitting a scan control word to the SCI. If 
a scan-out is required, the translator also 
transmits the scan-out information to the SCI. 
Upon completion of the scan operation by the 
SCI, the translator is notified. In the case of 
a scan-in operation, the scan-in information is 
loaded into the translator B register. If an er- 
ror has been detected by the SCI, error infor- 
mation is loaded into the translator F register. 

There are two error conditions which can be 
reported to the translator by the SCI: 

a. Not Ready - If the DFO or DCP ad- 
dressed by the scan bus does not respond with 
a ready signal within 3 usee, a not ready error 
is reported to the translator. 

b. Module Error - If the DFO or DCP ad- 
dressed by the scan bus detects an error on a 
scan-out or scan-in operation, an error signal 
is transmitted to the SCI. The SCI then re- 
ports a scan error to the translator. 

SCAN INTERFACE 

A DFO is selected by means of the 8-bit 
EUD code presented over the scan address 
lines. An EU may be connected to 2 DFOs (di- 
rectly to one DFO and indirectly via it to the 
second DFO). Therefore, when the system 
places an EUD code on the scan bus lines in 
order to communicate with a DFO, both DFOs 
could respond were it not for a means of inhib- 
iting the response of one DFO. 
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Figure IV-2-6. DCI Unit 



This means is bit 7 (ES) of the scan address 
lines. If bit 7 is low, the DFO connected direct- 
ly to the referenced EIU is selected. If bit 7 is 
high the DFO connected indirectly to the ref- 
erenced EU is selected. During execution of 
the report request operation, the DFO res- 
ponds regardless of the state of bit 7, if it is 
not part of a DFO pair. The scan information 
lines constitute the scan-in and scan-out words 
during the corresponding operations. 

DCF> SCAN INTERFACE 

During scan-out operations (only scan-out 
orders are accepted by a DCP), the scan infor- 



mation lines constitute the scan-out word. The 
SCI provides a maximum of four DCP memory 
interfaces (see figure IV-2-6) in a DCI unit. 

The DCI unit contains all storage capability 
and controls required to interface with the 
DCP memory buses. The memory transfer op- 
erations performed are: 

a. Fetch (one word) 

b. Store with flashback (one word) 

c. Protected store with flashback (one word). 
If an interface is not used by a DCP, it may 

be used to accommodate a suitable device. 

All errors detected by the DCI or MIU for a 
DCI memory request are transmitted to the 
DCP that initiated the memory request. 
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SECTION 3 
PERIPHERALS AND CONTROL WORD FORMATS 

INPUT/OUTPUT CONTROL WORD (IOCW) 
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FIELD 


IOCW 


JBW1 




BIT S 


BIT S 


LINK 


47:1 


47:1 


ASCII 


46:1 


46:1 


SA 


45:1 


45:1 


I/O 


44:1 


44:1 


MINH 


43:1 


43:1 


TRA 


42:1 


42:1 


FML 


41:1 


41:1 


MP 


40:1 


40:1 


B/F 


39:1 


50:1 


TEST 


38:1 


- 


TCTL 


37:2 


49:2 


CT EXT 


- 


39:3 


FINAL 


_ 


36:17 


ADDRESS 






START 


- 


19:20 


ADDRESS 







DESCRIPTION 

SIDELINK. When set, indicates a sidelinked I/O is to be performed. Info 
about sidelink operation is in second word of IOCB. 

ASCII. 

SOFTWARE ATTENTION. When set, causes ATT bit in result descriptor to 

be set. 

INPUT/OUTPUT. 1 = READ; = WRITE 

MEMORY INHIBIT. 

TRANSLATE. Settings of ASCII, I/O, TRA and FML bits, taken together, 

determine what data translation, if any, is to be done. 

FRAME LENGTH. 1=8 bits; = 6 bits. 
MEMORY PROTECT. 

BACKWARD/FORWARD. 1 = BKWD; = FWD. 
TEST. 

TAG CONTROL. 

= Store SP tags (0); 1 = Store program tags (3); 

2 = Tag field transfer; 3 = Store DP tags (2). 

COUNT EXTENSION. Number of characters in fractional word part of data 

buffer. 

Memory address of last full word of buffer to be accessed by IOM, low 17 bits 

only. 

Memory address of first full word of buffer to be referenced; for a backward 

tape operation, this is not the buffer base address. 
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Job word 1 is built in the IOM and can be 
read from the B register (Panel 1, Row 3) in T- 
time 25 of start mode. Job word 2 (JBW2) 

STANDARD RESULT DESCRIPTOR 



passed to the data service unit is in all cases 
the channel described in detail on the fol- 
lowing pages. 
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Field 

TAG 

MEMORY 
ADDRESS 

CHAR 
COUNT 

UNIT 
NO 

ME3,ME2,ME1 
6:1 

5:1 



BITS DESCRIPTION 

50:3 = Normal; 4 = IOM unable to do sidelinked job. 
47:20 Pinal level 1 memory address (L1A). Hard load RD contains channel used in [32:5]. 



27:3 
24:8 



No. of last memory word characters validly executed by IOM. 

Unit No. of device on which job was executed. (Set only for mapped I/O). 

16:1 MEMORY RELATED ERRORS. Listed in order of decreasing priority. 



ME3 ME2 ME1 IOM* 

(i 


1 
1 
1 
1 



PER STORE DISPARITY. 

RAE L1A ADDRESS-RESIDUE ERROR. 

FIR MCM-DETECTED ERROR, FAIL 1 (UNCORRECTABLE). 

NOA NO ACCESS TO MEMORY. 

PER FETCH DISPARITY. 

RSI MEMORY-PROTECT ERROR. 











F2R MCM-DETECTED ERROR, FAIL 2 (CORRECTABLE). 



*Panel Light indication in Error Control Register (Panel 2, Row 7). 
Unit or 15:9 Depends on value of bit 4 (DSE). 

DSU error 
bits 

= unit related errors (in bits 15:9); see below. 

1 = DSU error (in bits 15:9), as follows: 

DEVICE-DETECTED ERROR. 

NOT BUSY ERROR. 

COMBINATION ERROR. 
COUNTER ERROR. 
INTERFACE ERROR. 
BUS PARITY ERROR. 
CONTROL PARITY ERROR. 
DATA PARITY ERROR (Always set if BSE-1). 

4:1 DATA SERVICE ERROR. 

1 == DSU error (in bits 15:9); 

== Unit related error (in bits 15:9). 

3:1 NC'T READY. 



DVE 


15:1 


NBE 


14:1 


CME 


12:1 


CTE 


11:1 


IFE 


10:1 


BSE 


9:1 


CPE 


8:1 


DPE 


7:1 



DSE 

NTR 
BSY 
ATT 
EXC 



2:1 CHANNEL BUSY ON INITIATE. 
1:1 SOFTWARE ATTENTION. 
0:1 EXCEPTION. 
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UNIT RELATED ERRORS 

The device RD for any type of unit is re- 
turned to the IOM as 3 hex digits from the 



control. For a PCI operation, the device RD is 
in the PCI byte buffer (Panel 1, Row 14), as 
shown below, when the operation completes. 
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U= UNIT NO. FOR AN EXCHANGE DEVICE, ELSE UNUSED 



The INA8 bit should always be on, signify- 
ing operation complete. A unit error is signi- device RD are used to make up the RD error 
fied by INA4 = 1, and the remaining bits in the field reported to the MCP as shown: 
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For each PCI channel, the last RD returned 
to the MCP may be displayed in the RD regis- 
ter (Panel 1, Row 34) of the IOM via local 
memory operations. Similarly, the last RD 



from each DFI channel may be displayed (in 
slightly modified form) in the DFI RD register 
(Panel 1, Row 10). 



RESULT DESCRIPTORS COMMON TO ALL PERIPHERAL DEVICES 



0003 ATT (Software Attention) 

0005 BSY 

0009 NOT READY 

000D WRONG LENGTH DATA TRANSFER 

(Generated by MCP) 

0015 BUSS PARITY (Reported by MCP for 

hardware RD=0291) 

0021 MEMORY FAIL 2 (Correctable) 

0041 RESIDUE ERROR 

0061 STORE DISPARITY 

0291 BUS PARITY (Changed to 0015 by MCP) 

10001 MEMORY PROTECT ERROR 

10021 NO ACCESS TO MEMORY 

10041 FETCH DISPARITY 

10061 MEMORY FAIL 1 (Uncorrectable) 



Any result descriptor may also have ATT (bit 1) set. 
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FAIL RESULT DESCRIPTOR 
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FIELD 

MEMORY 
ADDRESS 



CHANNEL 
NUMBER 

MEM ERR 
CODE 



BITS 



DESCRIPTION 



FIELD 



BITS 



DESCRIPTION 



47:20 This field contains the location in 
memory that was last accessed at 
the time of the error. This field is 
not valid if bit 15 (ACE) is set. 

32:5 This field contains a channel 

number only when bit 15 (ACE) is 
set. 

27:3 This field contains a memory error 
code and is valid only when bit 16 
(ME) is set. The error bits are 
interpreted as follows: 

1 = Memory detected error. 

2 = L1A address residue error. 

3 = Store disparity. 

4 = Memory protect error. 

5 = No access to memory. 

6 = Fetch disparity. 

7 = Memory detected error. 



UNIT DES. 24:8 



ME 



ACE 



= A Unit Designate of all zeros 
signifies a Fail Register Result 
Descriptor. 

16:1 MEMORY ERROR. The memory 
error or MIU detected error is 
found by decoding bits 27:3 of the 
Fail Register. 

15:1 ACTIVE CHANNEL STACK 
ERROR. The address (channel 
number) of the word in the stack 
that caused the parity error is 
contained in bits 47:20. 

14:6 If SNE (7:1) = 0, then bits 14:6 are 
defined as follows: 

14:1 RSE RESIDUE ERROR 

(MEMORY ADDRESS). 
The address in error is 
contained in bits 47:20. 

13:1 BE BUFFER REGISTER 
PARITY ERROR. 

12:1 HAE HOME ADDRESS 

ILLEGAL COMMAND. 



TLK 



SNE 



EXC 



11:1 IBE INITIATE BUSY 

CHANNEL ERROR. An 
attempt was made to 
start a non-exchange 
channel that was either 
busy or in the process 
of being terminated. 

10:1 TOE TIME OUT ERROR. A 
data service time out 
error. 

14:6 If SNE (7:1) = 1, then bits 14:6 
represent scan errors and are 
defined as follows: 

14:1 NAQE NO ACCESS TO DFO 
EXCHANGE. 

13:1 SUNA STORAGE UNIT NOT 
AVAILABLE. 

12:1 QSE DFO STACK PARITY 
ERROR. 

11:1 DAE DISK ADDRESS 
ERROR. 

10:1 TOE TIME OUT ERROR. A 
scan buss time out error. 

9:1 SBE SCAN BUSS ERROR. 
Indicates a parity error 
on the scan bus. 

8:1 TABLE LOCKED. The translator 
timed out trying to fetch a locked 
Unit Table or Status Queue header. 

7:1 SCAN ERROR. When set, indicates 
that bits 14:6 represent scan errors. 

6:5 Indicate the translator mode of 

operation when the error occurred 
as follows: 

6:1 SNM SCAN MODE. 

5:1 RWM RING WALK MODE. 

4:1 TM TERMINATE MODE. 

3:1 SM START MODE. 

2:1 HM HOME ADDRESS MODE. 

0:1 EXCEPTION BIT. Indicates that a 
"1" exists in the Fail Register. 
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CARD PUNCH 



OPERATIONS 



CARD PUNCH CONTROL 

The B 7212 Card Punch Control is used with 
the B 9213 "300 CPM Punch" which can punch 
either Binary, Alpha, or EBCDIC code at a 
rate of 300 cards per minute. Pre-punched 
cards may be used, but previously punched col- 
umns cannot be repunched. The Card Punch 
has a 1000-card capacity input hopper, and 
three output stackers (primary, auxiliary, and 
error) which have a capacity of 1200 card each. 
Stacker selection is accomplished programmat- 
ically. 

CDL WORD FORMAT 
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FIELD 






OP VAR 


ADDR 


Operation 


23 SIII 




Punch BCL 


24 SIII 




Punch 
Binary 


25 SIII 




Punch 
EBCDIC 


99 IIII 




Test 



S = stacker; = normal, 1 = auxiliary, I = ignored 



IOCW FORMATION 
Operation 



BCL from Int. BCL 
BCL from ASCII 
BCL from EBCDIC 
Binary (6-bit from 6-bit) 
EBCDIC from EBCDIC 
EBCDIC from ASCII 



IOCW Bits 


CDL 


46 42 41 


OP Code 


10 


23 


110 


23 


11 


23 





24 


1 


25 


10 1 


25 



RESULT DESCRIPTOR, UNIT ERROR FIELD 

To From Device Error Type 

MCP 

0081 D00 Punch Check or Memory Access 

Error 
0281 D40 Parity Error 

0881 D10 Bus Parity Error 

A test-op returns the punch type in bit 10 of the software 
RD: = Model I; 1 = Model II. 



BCL (OP 23) 

Punch one card on the card punch. The oper- 
ation is terminated by punching the specified 
number of words or punching 80 columns. The 
descriptor word count cannot exceed 10 words 
for punch BCL. BCL Internal Code, ASCII, or 
EBCDIC is converted t j BCL code by transla- 
tors in the IOM. The control can include one 
and only one of the following translators 
which are used to convert BCL code to BCL 
card code, ICT card code or BULL card code. 

a. BCL-BCL Card Code Translator 

b. BCL-ICT Card Code Translator 

c. BCL-BULL Card Code Translator 

BINARY (OP 24) 

Punch one card on the card punch. The oper- 
ation is terminated by punching the specified 
number of words or by punching 80 columns. 
The descriptor word count cannot exceed 20 
words for punch binary. A total of 160 six-bit 
characters of memory are required to punch 
80 columns. The contents of each card column 
are divided into two 6-bit characters. The up- 
per six bits are punched from the first 6-bit 
character received and the lower six bits from 
the next 6-bit character. Tag field transfers 
are compatible with this operator and must 
not be specified. 

CARD PUNCH EBCDIC (OP 25) 

Punch one card on the card punch. The oper- 
ation is terminated by punching the specified 
number of words or by punching 80 columns. 
The descriptor word count cannot exceed 13 
words for punch EBCDIC. ASCII is translated 
to EBCDIC by translators in the IOM. The 
card punch control converts EBCDIC 8-bit 
code to EBCDIC card code. 



TEST (OP 99) 

Test the status of the unit and return a 
suit descriptor. 



re- 



PUNCH CHECK ERROR 

When a Punch Check is detected by Card 
Punch Control 1, the punching of that card is 
completed. The next card is punched and both 
cards are sent to the error stacker. The punch 
check bit is set in the result descriptor re- 
turned for the second card. 

When Punch Check is detected by Card 
Punch Control 2, the punching of that card is 
completed, and it is sent to the error stacker. 
The Punch Check bit in the result descriptor is 
set. 

The Punch Check bit may be present in the 
Result Descriptor when addressing a non-pres- 
ent punch, or one that is powered down. 



4-36 



CARD READER CONTROL 

The B 7110 Card Reader Control can be used 
with either B 9111 (800 cpm) or B 9112 (1400 
cpim) card readers. The input hopper and the 
output stacker have a capacity of 2400 cards 
each. The card readers accept alpha, binary or 
EBCDIC card codes. The card reader converts 
alpha card code to BCL, which is then con- 
verted into internal BCL or EBCDIC by trans- 
lators in the I/O Processor. EBCDIC card code 
is converted to internal EBCDIC by the B 7110 
card reader control. When binary punched 
cards are read no translation is made. 

The card readers can read 51-, 60-, or 80-col- 
umn punched cards. Optional features include 
the ability to read 40-column Treasury checks 
and round holes in Postal Money Orders. 
Cards of varying thickness are acceptable; 
however, card thickness and length must be 
consistent during any one run. 



CDL WORD FORMAT 
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FIELD 



OP VAR 


Operation 




20 mi 

21 IIII 

22 mi 
99 mi 


Read BCL 
Read Binary 
Read EBCDIC 

Test 




1 = ignored 






IOCW INFORMATION 






Operation 


IOCW Bits 


CDL 




46 42 41 


OP Code 


BCL to Int. BCL 
BCL to ASCII 
BCL to EBCDIC 
Binary (60bit to 6-bit) 
EBCDIC to EBCDIC 
EBCDIC to ASCII 


10 
110 
11 

1 
10 1 


20 
20 
20 
21 
22 
22 



RESULT DESCRIPTOR, UNIT ERROR FIELD 
To From Device Error Type 

MCP 

Memory-Access Error 

Read Check 

Validity Check 

Read Check and Validity Check 

Control Card (generated by IOM) 

Bus Parity Error 

Bus Parity Error in Initiate 

Phase* 



0081 


D00 


0101 


C80 


0281 


D40 


0381 


C80 


0401 


D40 


0881 


D10 


0889 


F10 


*3A Control 


only 


OPERATIONS 



BCL (OP 20) 

Read one card from the card reader. The op- 
eration is terminated by reading the specified 
number of words, or by receiving 80 characters 
from the reader. The card reader converts 
BCL card code to BCL code. BCL Code is con- 
verted to BCL Internal Control Code, ASCII, 
or EBCDIC by translators in the IOM. 

BINARY (OP 21) 

Read one card from the card reader. The op- 
eration is terminated by reading the specified 
number of words, or by receiving 80 columns 
of information from the reader. The contents 
of each card column are divided into two 6-bit 
fields. The upper six bits are stored in memory 
followed by the lower 6-bits. There is no code 
translation or invalid code detection Tag field 
transfers are not compatible with this 
operator and must not be specified. 

EBCDIC (OP 22) 

Read one card from the card reader. The op- 
eration is terminated by reading the specified 
number of words, or by receiving 80 characters 
from the reader. The card reader control con- 
verts EBCDIC card code to EBCDIC. EBCDIC 
is stored as received, or is translated to ASCII 
by the IOM. 

TEST (OP 99) 

Test the status of the unit and return a re- 
sult descriptor. 

DISK FILE SUBSYSTEM 

A disk file subsystem can include from one 
to eight controls and from one to twenty elec- 
tronics units. If more than eight controls are 
used, they must be divided between IOM's so 
that not more than 8 controls of 1 subsystem 
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are allocated to one IOM. Model 1A-2, 1C-3, 
and 1C-4 disks may be mixed in the same sub- 
system but model 2B disks must have a 
separate subsystem. 

A disk file exchange is required when more 
than two electronics units are used. A 1 x 2 
adapter may be used when two E.U.'s are re- 
quired. A segment size of 180 bytes 
(equivalent to 240 6-bit characters) is used in 
the B 7700 systems. The Disk File Control 4 is 
used to control disk file electronic units for 
model 1C and 1A-2 disks. 

The Disk File Control 5 is used to control 
disk file electronic units for model 2B disk. 

DISK FILE EXCHANGES 

From 1 to 4 disk file controls can be used to 
form a multiple control subsystem connected 
to a single IOM. 

The 4 x 10 disk file exchange is used to in- 
terface disk file control 4 with Model 1 Disk 
Electronic Units when multiple controls and/or 
E.U.'s are required in a subsystem. The 
maximum combination for this exchange is 4 
controls and 10 E.U.'s. The number of E.U.'s 
may be extended up to 20 by adding the 4 x 20 
disk file exchange extension and the appropri- 
ate adapters. 

The 4 x 20 Disk File Exchange 5 is used to 
interface Disk File Control 5 with the Model 
2B Disk Electronic Units when multiple con- 
trols and/or E.U.'s are required in a subsys- 
tem. 

The maximum combination for this ex- 
change is 4 controls and 20 E.U.'s. The number 
of E.U.'s may be extended up to 8 by adding 
the 8 x 20 disk file exchange extension and the 
appropriate adapters. 

A maximum of 8 controls for a given subsys- 
tem are allowed on an IOM. If the 8 x 20 ex- 
tension is used, more than 1 IOM DF adapter 
is required and the maximum of 4 controls per 
DFI adapter must be maintained. 

EXCHANGE MODULARITY 

The exchanges are modular by the use of 
adapters. The modularity of the adapters is 
such that E.U.'s and controls are added in in- 
crements of 2 until the maximum complement 
is reached. 

DISK 

CDL WORD FORMAT 
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FIELD 
OP VAR 

50 VFGM 

51 VFGM 

52 VFGM 
99 VFii 



ADDR Operation 

AAAAAA Write 
AAAAAA Read 
AAAAAA Check 
Test 



V = EU No. (LSD of unit designate) 

F: (35:2) = MSD of position on exchange, (33:2) = MSD of 

disk address 

G = MSD of EU unit designate, used for DFO operations 

M:l = maintenance segment 

A = Disk segment address (6 decimal digits) 

i = Ignored 



IOCW INFORMATION 
OPERATION 



IOCW Bits 
46 44 43 42 41 



WRITE 1 

READ 10 1 

CHECK 110 1 

RESULT DESCRIPTOR, UNIT ERROR FIELD 
To From Device Error Type 



COL OP 

Code 

50 
51 
52 



MCP 






0081 


DOO 


Memory-Access Error 


0101 


C80 


EU Busy 


0201 


C40 


Write Lockout 


0281 


D40 


Parity Error 


0881 


D10 


Bus Parity Error 


8001 


C01 


Timeout 



A test-op returns the diskfile type in [11:2] of the RD to 

Sof t W &YG 

For type IV (DISKI) disk: = 1A2, 1 = 1C3, 3 = 1C4. 
For type V (DISKII) disk: = 2B2, 1 = 2B6, 2 = 2B4. 

OPERATIONS 

WRITE (OP 50) 

Write a record on the disk file. The operation 
is terminated by writing the specified number 
of words. Incomplete segments are filled out 
with NULL characters (0000 0000) by the disk 
file control. 

READ (OP 51) 

Read a record from the disk file. The 
operation is terminated by reading the 
specified number of words. 

CHECK (OP 52) 

Read a record from the disk file, but do not 
store any information in memory. If a read er- 
ror is encountered, the control sets the read 
error bit in the result descriptor. 

ERROR TERMINATION 

If, during a read or check operation, a seg- 
ment parity error is detected, the operation is 
terminated. 

If, during read, check or write operations, a 
failure to access the IOM is encountered, ac- 
cesses are terminated and result descriptor re- 
turned when the segment is completed. Writes 
are completed with NULL characters (0000 
0000), and a result descriptor stored. 

The control will time out if the unit ad- 
dressed sends no information for more than 
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one disk revolution. The time out bit is set in 
the result descriptor. 

Changing zones or changing disks within a 
storage unit does not result in a time loss of 
more than 600 microseconds. Changing storage 
units can result in a time loss equivalent to 
one disk revolution. 

DISK-PACK DRIVE MEMORY SYSTEM 

The Magnetic Actuator Disk-Pack Drive 
Memory Systems are extremely high-speed, 
modular, random information storage systems. 
A basic disk-pack drive memory subsystem in- 
cludes the disk-pack drive controller, dual disk- 
pack drive, and the interconnecting cables. 

The controller acts upon I/O instructions 
from the IOM, powers the disk-pack drive, and 
transfers information between disk-pack 
drives and the IOM. The controller performs 
the operation specified by the OP code (and 
variants) of the CDL Word, and, at the comple- 
tion of the operation, generates a result de- 
scriptor which contains operation and/or error 
status information. 

The disk-pack drive controller with single ac- 
cess capabilities may be used with eight disk- 
pack spindles (four dual drives) in a one-by- 
eight configuration, or two groups of eight 
disk-pack spindles (eight dual drives) in a one- 
by-16 configuration. Selection of each group is 
determined by a variant in the I/O descriptor. 
The disk-pack drive controller with dual access 
capability may be used in a two-by-eight con- 
figuration in which the disk-pack drive con- 
troller contains two internal control units. 
This allows the I/O module to execute two si- 
multaneous operations (two reads, two writes, 
or a read and a write). This configuration can 
be expanded to a two-by-16 configuration. 

CDL WORD, GENERAL FORMAT 





47 


43 


u 

39 


35 


31 


27 


23 


19 


15 


11 


7 


3 




50 




46 


P 
42 


N 

38 


VAF 

34 


IAN 

30 


T 
26 


22 


18 


Fl 

14 


10 


6 


2 




49 


CO 

45 


PE 

41 


1 

37 


33 


29 


25 


21 


A 

17 


DD( 

13 


9 


5 


1 


48 


44 


40 


T 

36 


32 


28 


24 


20 


16 


12 


8 


4 






OP 


VAR 


ADDR 


Operation 


so 


USFV 


AAAAAA 


Write 


51 


USFV 


AAAAAA 


Read 


53 






Report (reserved for FPM) 


i>4 






Unlock (reserved for FPM) 


55 






Gear (reserved for FPM) 


56 


USFV 


AAAAAA 


Initialize 


57 


USFV 


AAAAAA 


Verify 


58 


USFN 


AAAAAA 


Relocate 


99 


UVii 




Test 



U = Unit Designate (LSD); A = Disk Pack Address (six 
decimal digits) 

SI: unconditional/conditional operation 

S2: 1 = disable automatic restore function following 
seek error 

Fl: 1 = full-track format, = multisector format (full- 
track format is unimplemented for 225 DPD.) 

V = Variant (differs for each operation); N = Spare Sec- 
tor 

i = Ignored 

CDL WORD FORMAT, WRITE (OP 50) 





47 


43 


U 
39 


S8 


31 


21 


23 


19 


15 


11 


7 


3 




50 




46 


P 

42 


N 

38 


S4 

34 


3C 


V4 

26 


22 


DISK 

18 14 


PACK 

10 6 


2 




49 


CODE 

45 41 


1 

37 


S2 

33 


2S 


25 


21 


ADDRESS 

17 13 9 5 


1 




48 


44 


40 


T 

36 


SI 

32 


Fl 

2£ 


24 


20 


16 


12 


8 


4 






S8: 
S4 
S2 
SI 



Fl: 

V4: 



1 = load controller firmware (BX 383 only, 

overrides all other CDL variants) 

1 = automatic data parity check on all sectors 

written after write operation. 

1 = disable automatic restore function 

following seek error. 

for BX380, = unconditional operation, 1 = 

conditional operation. 

for BX383, 1 = unconditional operation, = 

conditional operation. 

1 = full-track format, = multisector format 

Reserved for FPM 



CDL WORD FORMAT, READ (OP 51) 



50 



49 



43 



47 



OP 

46 



45 



44 



43 



42 



CODE 



41 



40 



39 



N 



38 



37 



36 




23 



22 



21 



20 



19 



DIS ' 



17 



16 



15 



IDDftESS 



13 



12 



11 



SF- 



9 



S8: 
S4: 
S2: 

SI: 



Spare 
Sector: 



Fl: 
V8.V4: 



1 = error correction is disabled. 

= normal read, 1 = read binary address field. 

1 = disable automatic restore following seek 
error. 

for BX380, = unconditional operation, 1 = 

conditional operation. 

for BX383, 1 = unconditional operation, = 

conditional operation. 

If S4=l, then value of 1-5 indicates a spare 

sector. Cylinder referenced will be that 
containing the specified disk pack address. 

1 == full-track format, = multisector format. 
1, = read log (BX383 only). 
V8 = 1 overrides all other CDL variants. 
1, 1 = dump buffer (BX383 only). 
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CDL WORD FORMAT, INITIALIZE (OP 56) 



CDL WORD FORMAT, RELOCATE (OP 58) 





47 


43 


u 

39 


35 


31 


27 


23 


19 


15 


11 


7 


3 






47 


43 


U 39 


35 


31 


27 


23 


19 


15 


11 


7 


3 




50 




4fi 


P 

4? 


N 

38 


34 


3(1 


V4 


22 


DISK 

18 14 


PACK 

10 6 


2 




O 5 o 




46 


P 

42 


N 38 


34 


30 


si 


22 


Dl 

18 


SK 

14 


PA 

10 


CK 

6 


2 




49 


<8 


DE 

41 


1 

37 


SS §3 


29 


V2 

25 


21 


/>DDRES!> 

17 13 9 5 


1 


49 


CODE 

45 41 


'37 


S2 

33 


29 


w 


21 


AD 

17 


DR 

13 


ES 

9 


s 

5 


1 




48 


44 


40 


T 
36 


SI 

32 


Fl 

28 


VI 

24 


20 


16 


12 


8 


4 





o 48 


44 


40 


36 


SI 

32 


Fl 

28 


B8 


20 


16 


12 


8 


4 






S2: 1 = disable automatic restor function following 

seek error. 
SI: for Bx380, = unconditional operation, 1 = 

conditional operation. 

for BX383, 1 = unconditional operation, = 

conditional operation. 
Fl: 1 = full-track format, = multisector format. 

V4: = write default pattern into each sector. 

BX380, all zeros. 

BX383, 215 DPD = "55E7", 225 DPD = "6363". 

1 = write provided test data pattern into each 

sector; first 16 bits of data buffer is used as 

test pattern. 
V2.V1: 0, = initialize entire pack, 0, 1 = initialize 

designated cylinder, 

1, = initialize designated track. Designated 

track and cylinder are those containing the 

specified disk pack address. 



CDL WORD FORMAT, VERIFY (OP 57) 




S2: 



SI: 



Fl: 



1 = disable automatic restore function 

following seek error. 

for BX380, = unconditional operation, 1 = 

conditional operation. 

for BX383, = conditional operation, 1 = 

unconditional operation. 

1 = full-track format, = multisector format. 
V8,V4: 0, = check data fields for parity only. 

1,0 = compare data fields against default 

pattern. 

x, 1 = compare data fields against last 

initialization pattern used. 
V2.V1: 0, = verify entire pack, terminate on first 

error. 

0, 1 = verify designated cylinder, report ~„ : U 
errors. 

1, = verify designated track, report all 
errors. 



S2: 



SI: 



Fl: 

Spare 

Sector: 



1 = disable automatic restore function 

following seek errvr. 

f vr BX380, = unconditional operation, 1 = 

conditional operation. 

for BX383, = conditional operation, 1 = 

unconditional operation. 

1 = full-track format, = multisector format 

The sector specified in the address field is 

relocated to the designated spare sector of the 
proper cylinder. 



CDL WORD FORMAT, TEST (OP 99) 




VI: 1 = selected drive is taken off-line for pack 

removal 



READ BINARY ADDRESS OPERATION 

A read binary address operation returns the 
address information written on the pack for 
the specified sector in the first word of the 
data buffer as follows: 

[47:8] = HEX "FF" 
[39:24] = sector address 
[15:15] = ignored 

The sector address is stored in cylinder - 
head (track) - sector form and has the fol- 
lowing format: 

[23:8] Sector 

[15:9] = Cylinder 

[6:6] = Head (track) 

[0:1] = Parity bit (overall parity is odd) 
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An unused spare sector has the spare num- 
ber in both the sector and head fields of its ad- 
dress. An unusable (relocated) sector will have 
all bits on in the sector address returned. An 
in-use spare sector contains the address of the 
sector that has been relocated to it, except 
that the sector field is modified by having the 
spare number added to it. 

SECTOR ADDRESS CONVERSION 

To convert a decimal disk pack address to 
cylinder-head (track) sector form, the algo- 
rithms are as follows: 



Cylinder = Address DIV CI. 
Head = ((Address MOD CI) +5) DIV C2. 
Sector = Address MOD CI (for Head = 0) 
Sector = ((Address MOD CI) +5) MOD C2 (for Head = 0) 
where 
CI = sectors per cylinder 
C2 = sectors per track (hea.d) 



For 215 Disk Pack Drives, CI = 655 and C2 = 33. 
For 225 Disk Pack Drives, CI = 1195 and C2 = 60. 

The last five sectors of track (head) of each 
cylinder are the spare sectors for that cylin- 
der. By convention, the last sector is spare 1, 
the next to last is spare 2, etc. Thus, for a 225 
DPD spare sector 5 for a cylinder is track 
(head) = 0, sector = 55 for that cylinder. 



IOCW 



Operation 


IOCW Bits 


CDL 




46 44 43 42 41 40 


OP 
Code 


Write 


10 


50 


Read 


10 10/1 


51 


Initialize 


10 


56 


Verify 


10 10/1 


57 


Relocate 


10 10 


58 



RESULT DESCRIPTOR, UNIT ERROR FIELD 



BX383 

Description 

Drive Not Ready/Not Present, Nonexistent Address, Unsafe 

Condition 

Memory Access Error 

Sector Address Parity Error 

Controller in Local 

Controller Cleared during Operation 

Drive Seeking 

First Action with Drive 

Drive Busy 

Speed Error during Initialize 

Write Lockout 

Data Error on Read 

Seek Error 

Control Malfunction 

Data Parity Error (System to HTC) 

Write Parity Error on Info Bus 

Command Parity Error (System to HTC) 

Sector Timeout 

Link Parity Error (DPDC to HTC) 

Seek Initiated 

Data 1-bit Error Correction on Read 

Address Position Error 

Seek Timeout 

Data Parity Error (HTC to DPDC) 

Transmission Parity Error 

Command Parity Error (HTC to DPDC) 

Data Correctable Error Retry on Read 

A test-op returns controller sind drive information in bits [15:2[ of the RD as follows: 
= drive not present, 1 = BX380 (215 DPD), 2 = BX383 with 215 DPD, 
3 = BX383 with 225 DPD. 



To 


From Device 


MCP 




0009 


E00 


0081 


D00 


0101 


C80 


0109 


E40 


0201 


C40 


0301 


CCO 


0401 


C20 


0481 


D20 


0501 


CA0 


0581 


DA0 


0801 


C10 


0809 


E10 


0881 


D10 


0889 


F10 


0901 


C90 


0981 


D90 


0A01 


C50 


0C01 


C30 


4101 


C82 


8801 


Cll 


8881 


Dll 


8889 


Fll 


C801 


C13 



BX380 


To 


From Device 


MCP 




0009 


E00 


0181 


D80 


0101 


C80 


0089 


F00 


0201 


C40 


0301 


CCO 


1001 


C08 


1081 


D08 


0501 


CA0 


0081 


D00 


0801 


C10 



0881 



0901 



D10 



C90 



0A01 


C50 


2801 


C14 


1101 


C88 


1801 


C18 


1181 


D88 
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OPERATIONS 

WRITE (OP CODE 50) 

Information is written from memory onto 
disk at the designated file address. Partial sec- 
tor writes result in a fill of bit zeros in the re- 
mainder of the sector. 

READ (OP CODE 51) 

Information is read from the selected file ad- 
dress into the main memory address. A partial 
sector read results in the termination of data 
transfer, but control release does not occur un- 
til completion of the total sector read. The con- 
troller times out if the read operation is not 
completed. 

INITIALIZE (OP CODE 56) 

The controller writes addresses and gaps on 
all tracks, starting with an index on the track 
of the designated address. The controller may 
also write a test pattern consisting of all 
zeros. 

VERIFY (OP CODE 57) 

The controller reads from the disk-pack and 
checks for address errors and information par- 
ity errors. The verification of disk sectors be- 
gins with the first sector following the index 
on the track specified by the disk file address 
and continues through the entire track, cylin- 
der, or disk-pack. The sector positions are 
verified by counting from the index on each 
trjiclc 

The BCD file address (normal or spare) con- 
taining the detected error(s) is reported back 
between the begin and end memory address 
(or between the begin address plus 6 bytes and 
the end address if V 4 is 1). Address parity 
checked for all relocated sectors. 

RELOCATE (OP CODE 58) 

The controller flags the sector address field 
of the unusable sector with an error 
configuration and rewrites this address in the 
spare sector. The original address field and 
the relocated address field are located by 
counting from the index on each track. 

NOTE 
An error configuration is one byte 
of binary "ones" with clock pulses 
omitted, followed by one byte of bi- 
nary "ones" (with clock pulses), fol- 
lowed by one byte of binary "ones" 
with clock pulses omitted. 

The error configuration is written into the 
address field of the designated sector. The 
standard test data pattern is written into the 
relocated sector data field. If full-track format 
is specified, the address is flagged but no relo- 
cation takes place. 



TEST (OP CODE 99) 

The controller returns an appropriate result 
descriptor indicating the type of drive access- 
ed, the peripheral control type, and (in a 
shared system configuration), the number of 
the assigned processor. 

EXCEPTION CONDITIONS 

SINGLE BIT ERROR CORRECTION (SBE) 

A single bit error in a 90-byte data block is 
detected and corrected during a read 
operation. 

DISK-PACK DRIVE BUSY (TIME-OUT) (DRB) 

The operation is terminated if the drive ac- 
cessed is being used by another controller as 
an operation is initiated and the drive does not 
become available within 50 milliseconds. 

SPEED ERROR (1081) 

The operation is terminated if there is a fail- 
ure to write a full track of information be- 
tween index pulses during an initialize 
operation. 

ADDRESS POSITION ERROR (VERIFY) (1101) 

A valid address is found at the wrong posi- 
tion relative to the index during a verify oper- 
ation. 

TRANSMISSION PARITY ERROR (1181) 

The operation is terminated at the end of the 
sector being processed if a parity error is de- 
tected while data is being transmitted during 
a write operation. 

SEEK TIME-OUT (1801) 

The controller terminates the operation 
when an accessed drive fails to complete the 
initiated seek within one second. 

SEEK ERROR (DSK) 

Bit 8 is set and the operation is terminated 
if a seek is initiated which positions the heads 
over the wrong cylinder during a read or write 
operation (as verified by the controller reading 
the address field from the track on the cylin- 
der in question). Bit 8 is set and the operation 
is not terminated if a seek is initiated which 
positions the heads over the wrong cylinder 
during a verify operation. 

SECTOR TIME-OUT (0901) 

The operation is terminated if a specified 
sector address, or spare sector to which that 
address has been relocated, cannot be found 
during a read, write, or relocate operation. 

WRITE-LOCKOUT (0501) 

A write, initialize, or relocate operation is 
not initiated if the drive to be accessed is in 
the write lockout state. (The operator failed to 
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press the WRITE ENABLE button on the 
drive unit.) On a test operation, if the drive is 
detected to be in a write lockout state, the op- 
eration will be executed and bits 5 and 7 will 
be set in the test result descriptor. 

FIRST ACTION (0301) 

At the beginning of any operation, if it is de- 
tected that this is the first command to a drive 
that has been powered up, the operation is not 
initiated. 

MEMORY INTERFACE PARITY ERROR (0081) 

The controller terminates the operation at 
the end of the sector being processed if an in- 
formation parity error is detected on the mem- 
ory or I/O Processor ^interface. 

CONTROL CLEARED (0089) 

If the disk pack controller is cleared during 
any operation, the operation in process is ter- 
minated. The termination is instantaneous 
and if the controller was writing to the disk at 
the time Clear was detected, it could destroy 
the information on the track. 



GENERAL INFORMATION 

Each disk pack contains 11 disks and 20 re- 
cording surfaces, each surface accessed by an 
individual arm from the actuator. Each disk 
surface contains 406 tracks. (See figure IV-3- 
1). 



The data transfer is bit-serial. The 
maximum byte capacity, transfer rate, and 
other pertinent information for the various 
disk-pack subsystem are presented in table IV- 
3-1. 



MULTISECTOR-PER-TRACK (STANDARD) 
FORMAT 

There are 33 sectors/track in the multisector 
format (table IV-3-2), and information within 
the track is located by sector address (pack ad- 
dress). When a pack is initialized, addresses 
are written sequentially, sector by sector, 
throughout each cylinder in the disk-pack. 



TRACK • 



ACCESS ARMS- 



READ/WRITE HEADS 
(0-19) 




DISK SURFACES 



Figure IV-3-1. Disk-Pack Recording Surfaces 
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Table IV-3-1. Disk-Pack Subsystem Characteristics 



DISK PACK 

DRIVE 
STYLE NO. 


.... 

DESCRIPTION 


AVERAGE 

ACCESS 

TIME (MS) 


AVERAGE 

LATENCY 

(MS) 


STORAGE CAPACITY 


DATA 

TRANSFER 

RATE 


PACK DATA 


PER DISK-PACK DRIVE 


MAX. 
RECORDING 
DENSITY (BPI) 


TRACK 

DENSITY 

(TPI) 


DISK- PACK 
STYLE NO. 


MULTI-SECTOR 
MODE* 


FULL TRACK 
MODE* 


B 9484-3 


Dual drive with 
single access 
disk-pack drive 
controller 
(B 7380-1) 


30 


12.5 


95.5 


121.0 


312.5 KB 


2200 


200 


B 9974-1 


B 9485-3 


Dual drive with 
dual access 
disk-pack drive 
controller 
(B 7380-2) 


30 


12.5 


95.5 


121.0 


312.5 KB 


2200 


200 


B 9974-1 


B 9486-3 


Dual drive add 
on without disk- 
pack drive con- 
troller 


30 


12.5 


95.5 


121.0 


312.5 KB 


2200 


200 


B 9974-1 


B 9484-4 


Dual drive with 
single access 
disk-pack drive 
controller 
(B 7383-1) 


30 


12.5 


174.4 


242.0 


625.0 KB 


4400 


200 


B 9974-4 


B 9485-4 


Dual drive with 
dual access 
disk-pack drive 
controller 
(B 7383-2) 


30 


12.5 


174.4 


242.0 


625.0 KB 


4400 


200 


B 9974-4 


B 9486-4 


Dual drive add 
on without disk- 
pack drive con- 
troller 


30 


12.5 


174.4 


242.0 


625.0 KB 


4400 


200 


B 9974-4 


B 9486-45 
♦Million ei 


Single drive add 
on without disk- 
pack drive con- 
troller 

ght-bit bytes. 
1 


30 


12.5 


87.2 


121.0 


625.0 KB 


4400 


200 


B 9974-4 



Table IV-3-2. Disk-Pack File Addresses (Burroughs Multi-Sector Format) 



(n 





HEAD 


HEAD 1 


HEAD 2 


HEAD 18 


HEAD 19 


CYL. 
NO. 


SECTOR 


FILE 


SECTOR 


FILE 


SECTOR 


FILE 


SECTOR 


FILE 


SECTOR 


FILE 


ADDRESS 


ADDRESS 


ADDRESS 


ADDRESS 


ADDRESS 




Spare 
Sectors 



1 

27 


000000 
000001 

j-* r\ r\ r\ s\ <"» 

000027 




1 
2 

27 
28 
29 
30 
31 
32 


000028 
000029 
000030 

000055 
000056 
000057 
000058 
000059 
000060 




1 
2 

27 
28 
29 
30 
31 
32 


000061 
000062 
UUUObJ 

000088 
000089 
000090 
000091 
000092 
000093 




1 
2 

27 
28 
29 
30 
31 
32 


000589 
000590 
000591 

000616 
000617 
000618 
000619 
000620 
000621 




1 
2 

27 
28 
29 
30 
31 
32 


000622 
000623 
000624 

000649 
000650 
000651 
000652 
000653 
000654 


f 28 

29 

< 30 

31 

I 32 


*Addr+ 1 
Addr+2 
Addr+3 
Addr+ 4 
Addr+5 


1 

Spare 
Sectors 




1 
2 

27 


000655 
000656 
000657 

000682 


o 

1 
2 

27 
28 
29 
30 
31 
32 


000683 
000684 
000685 

000710 
000711 
000712 
000713 
000714 
000715 


n 

1 
2 

27 
28 
29 
30 
31 
32 


000717 
000718 

000743 
000744 

000745 
000746 
000747 
000748 


n 
\j 

1 

2 

27 
28 
29 
30 
31 
32 


001245 
001246 

001271 
nm oio 

001273 
001274 
001275 
001276 


\J 

l 
2 

27 

OQ 

29 
30 
31 
32 


r\r\ i or? t-r 
\J\J±& i t 

001278 
001279 

001304 

r\r\i on c 
\j \j j. <j\j «j 

001306 
001307 
001308 
001309 


r 28 

[ 29 

< 30 

31 

L 32 


Addr+ 1 
Addr+2 
Addr+3 
Addr+4 
Addr+5 


405 

Spare 
Sectors 




1 
2 

27 


265275 
265276 
265277 

265302 



1 
2 

27 
28 
29 
30 
31 
32 


265303 
265304 
265305 

265330 
265331 
265332 
265333 
265334 
265335 



1 

2 

27 
28 
29 
30 
31 
32 


265336 
265337 
265338 

265363 
265364 
265365 
265366 
265367 
265368 



i 

2 

27 
28 
29 
30 
31 
32 


265864 
265865 
265866 

265891 
265892 
265893 
265894 
265895 
265896 




1 

JL 

2 

27 
28 
29 
30 
31 
32 


265897 
265898 
265899 

265924 
265925 
265926 
265927 
265928 
265929 


f 28 

29 
< 30 

31 
I 32 | 


Addr+ 1 
Addr+2 
Addr+3 
Addr+4 
Addr+5 



* Address of last non-spare sector, plus number of spare (1-5) specified in F variant. 



The segment size of Burroughs magnetic ac- 
tuator disk-pack drives can be selected by the 
user as either 180-bytes or full track of 7470 or 
14,940 bytes. When the 180-byte segment or 
multi-sector mode is selected, inter-record gaps 
are introduced and, accordingly, as on all disk- 
packs where the full-track facility is not used, 
the 121,000,000-byte capacity will be reduced to 
95,500,000 bytes; the 242,000,000 byte capacity 
will be reduced to 174,400,000 bytes. 

SPARE SECTORS 

Five sectors are reserved for each cylinder 
on track 00 (surface under head 00) for relocat- 
ing data from other sectors in the disk-pack 
which have been designated as unusable. Data 
will be relocated between tracks in the same 
cylinder only. 

The method of locating spare sectors so that 
data is not lost is a software function. If more 
than five unusable sectors are encountered in 
one cylinder, the additional unusable sectors 
are disposed of by software via the XP mes- 
sage. 

One format is used to address all sectors 
which are not spares. This format uses a con- 
tinuous 6-digit BCD address to designate con- 
tiguous sectors beginning at sector (first sec- 
tor after index) on head 0, cylinder and con- 
tinuing by sector, head, and cylinder in that 
order. The BCD file address may be related to 
the actual disk-pack cylinder head and sector 
by the following equalities: 

a. Burroughs Multi-Sector Format (figure 
IV-3-2): 

For head 0: (655*cylinder) + sector = file address 

For other heads: (655*cylinder) + (33*head) + (sector-5) = 

file address. 



b. Single Sector/Track Format (figure IV-3- 
3): 

For all heads: (20*cylinder) + head - file address. 

The other format is the single sector per 
track format (table IV-3-3). In figure IV-3-3 
the entire track is shown first, followed by an 
enlargement of the data and address fields. 
There are no spares in this format. 

Spare sectors (sectors 28 through 32) on sur- 
face of each cylinder are addressed with the 
following six-digit patterns: 

a. Two digits of undigit 5's (F) to delimit the 
field. 

b. Three BCD digits to indicate the cylinder 
on which the spare is located. 

c. One BCD digit indicating spare sector L 
through 5 as needed. 



UNDIGIT 
5 


SPARE 
SECTOR 


UNDIGIT 
S 



LINE PRINTER 

PRINTER CONTROL 

Four basic line printers are available for use 
on the B 7700 system. 

1. B 9242-11 - 860 LPM, 120 print positions 
(includes forms self-align feature). 

2. B 9243-11 - 1100 LPM, 120 print positions 
(includes forms self -align feature). 

3. B 9246-2 - 1800 LPM, 132 print positions. 

4. B 9247-14 - 1100 LPM, 132 print positions 
(includes 12-channel format tape reader). 



Table IV-3-3. Disk-Pack File Addresses (Single Sector/Track Format) 



CYL. 
NO. 


HEAD 


HEAD 1 


HEAD 2 


HEAD 18 


HEAD 19 


FILE ADDRESS 


FILE ADDRESS 


FILE ADDRESS 


FILE ADDRESS 


FILE ADDRESS 





000000 


000001 


000002 


000018 


000019 


1 


000020 


000021 


000022 


000038 


000039 


2 


000040 


000041 


000042 


000058 


000059 


3 


000060 


000061 


000062 


000078 


000079 


405 


008100 


008101 


008102 


008118 


008119 
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TRACK FORMAT (MULTI -SECTOR MODE) 



COMPLETE TRACK 



BOT GAP (A.) 



24 BYTES 
(No specific 
pattern) 



ADDRESS SYNC - 9 BYTES 



5 BYTES 
Binary "ones" 



2 BYTES 
Binary "zeros" 



Reserved for Sync VFO 
variation in 
detection of 
index 



Lock phase 
of VFO 



1 BYTE 
* "ones' 



1 BYTE 
Binary "ones" 



* Clock pulses 
omitted 



Code 





SECTOR A 


DDRESS - 


3 BYTES 




PREAMBLE 


GAP - 11 


BYTES 




1 BIT 
Flag 


7 BITS 
Sector 


9 BITS 
Cyl 


6 BITS 
Head 


1 BIT 
Parity 


3 BYTES 

(No specific 

pattern) 


5 BYTES 

Binary 

"ones" 


2 BYTES 

Binary 

"zeros" 


1 BYTE 
Binary 
"ones" 


Set if 
sector 
is a 
spare 










Read to Write 
switch time 


Sync 
VFO 


Lock 
phase 
of VFO 


Code 



DATA FIELD - 184 BYTES (LESS 2 BITS) 



90 BYTES 
Data 



11 BITS 
Check 
code * 



90 BYTES 
Data 



11 BITS 
Check 
code * 



♦Error correction for 90 
bytes of data 



I 



1 BYTE 
Count ** 
character 



** 8-bit count of 
ones - excess 
256 (detects 
multiple bit 
errors not de- 
tected by 11- 
bit check code) 



Figure IV-3-2. Standard Format (Sheet 1 of 2) 
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POSTAMBLE GAP 


- 24 BYTES 


[B) EOT GAP - 42 to 


353 BYTES , 


9 BYTES 
Binary "ones" 


15 BYTES 
Binary "ones" 


to 311 BYTES 
(No specific 
pattern) 


42 BYTES 
Spare 



Reserved for Reserved for 

space varia- Write to Read 

tion in writing switch time 
data 



Reserved for 
speed varia- 
tion (+ 2%) 



Note: (A) through (B) is repeated 32 times except no postamble on last sector. 



ADDRESS FIELD OF SECTOR FLAGGED AS AN ERROR SECTOR (PLUS LAST TWO BYTES OF 
ADDRESS SYNC) 



(PARTIAL) 


ADDRESS SYNC 




l 


/ \ BYTE 

N. *Binary "ones" 


1 BYTE 

Binary "zeroes" 


I BYTE 

♦Binary 

"ones" 


2 BYTES 

Binary 

"zeroes" 



*Clock pulses 
omitted 



Code byte changed 
to "zeroes" 



ADDRESS FIELD OF SECTOR WITH RELOCATED SECTOR INFORMATION 
SECTOR ADDRESS FIELD 



1 BIT 
Flag 



7 BITS 
Sector 



9 BITS 

CYL 



6 BITS 
Head 



Bit is 
a "zero" 



ADDRESS FIELD OF UNUSED SPARE SECTOR 
I SECTOR ADDRESS FIELD 



Bit is 
a "one' 



1 BIT 
Parity 



1 BIT 

Flag 


7 BITS 
Sector 


9 BITS 
CYL 


6 BITS 
Head 


1 BIT 
Parity 



Figure IV-3-2. Standard Format (Sheet 2 of 2) 
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COMPLETE TRACK 
BOT GAP 



<Aj> 



24 BYTES 

(No specific pattern) 



ADDRESS SYNC - 9 BYTES 



5 BYTES 
Binary "ones" 



A Reserved for vari- 
ation in detection 
of index (A) 



Sync VFO 



2 BYTES 
Binary "zeroes' 



1 BYTE 
* "ones' 



1 BYTE 
Binary "ones' 



Lock phase 
of VFO 



♦Clock 
pulses 
omitted 



Code 



SECTOR ADDRESS - 3 BYTES 



PREAMBLE GAP - 11 BYTES 



1 BYTE 
Binary "ones" 



9 BITS 
CYL 



6 BITS 
Head 



1 BIT 
Parity 



3 BYTES 
(No specific 
pattern) 



5 BYTES 

Binary 

"ones" 



2 BYTES 

Binary 

"zeroes' 



1 BYTE 

Binary 

"ones' 



Read to 


Sync 


Lock Code 


Write switch 


VFO 


phase of 


time 




VFO 



DATA FIELD - 7586 BYTES (LESS 7 BITS) 
(A) (B), 



90 BYTES 
Data 



11 BITS 

Check 

code* 



♦Error correction for 90 bytes 
of data 



1 BYTE 
Block 

count** 



(A) through (B) ♦♦8-bit count of "ones" 
repeated 82 times excess 256 (Detects 

multiple bit errors not 
detected by 11-bit check 
code) 



EOT GAP - 24 TO 335 BYTES 



to 311 BYTES 

(No specific pattern) 



24 BYTES 
Spare 



Reserved for speed 
variation (+ 2%) 



Figure IV-3-3. Single Sector For Track Format 
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The B 7240 printer control is used with ei- 
ther B 9242-11, B 9343-11, or B 9246-1 line 
printer. The B 7243 and B 7247 printer con- 
trols are used with the B 9247-13 and B 9247- 
14 line printers, respectively. 

CDL WORD FORMAT 





47 


43 


S39 


u 35 


S31 


C27 


23 


19 


15 


11 


7 


S 


°50 




46 


P 

42 


P 

A38 


N 34 


K 

1 30 


H 

A26 


22 


18 


14 


10 


6 


2 


°49 


CO 

45 


DE 

41 


C 

F37 


' 33 


P 

29 


N 

M25 


21 


17 


13 


9 


5 


1 


°48 


44 


40 


36 


'32 


1 

028 


E 

L.24 


20 


16 


12 


8 


4 






FIELD 

OP VAR 

10 SUNN 

11 

99 



SUNN 
iUii 



Operation 

Write 

Skip 

Test 



NN = Skip to Channel (00-11); two decimal digits. 
S = Space (0,1,2); ignored if NN = 0. 
U = Unit Designate (0 or 1) 
i = Ignored 



IOCW INFORMATION 
Operation 

BCL External (no trans.) 
BCL from Int. BCL 
BCL from ASCII 
BCL from EBCDIC 
Space or Skip 



RESULT DESCRIPTOR, UNIT ERROR FIELD 

To MCP From Device Error Type 



IOCW Bits 


CDL OP 


46 43 42 41 


Code 





10 


10 


10 


10 10 


10 


11 


10 


10 


11 



0181 


D80 


Bit-Transfer Error 


0281 


D40 


Buffer Parity 
Error 


0481 


D20 


Print Check/Code 
Parity 


0801 


C10 


Low Paper 


0881 


D10 


Bus Parity Error 


1001 


C08 


End-of-Page 


OPERATION 







BCL (OP 10) 

Print one line on the line printer. The length 
of the line is determined by the number of 
printer columns (120 or 132) or by printing the 
specified number of words. Spacing or skipping 
takes place after printing. 



When the 6-bit frame size is selected and 
control word bit 47 is false and control word 
bit 42 is true, BCL Internal code is converted 
to BCL code by a translator in the IOM. When 
the 8-bit frame size is selected and control 
word bit 42 is true, EBCDIC is converted to 
BCL code; when control word bits 47 and 42 
are true, ASCII is converted to BCL code. 

SPACE (OP ll) 

Space as specified by CDL word bits 37:2 
(bits 31:8 must be zero). 

00 No space 

01 Single space 
lx Double space 



SKIP (OP 11) 

Skip as specified by CDL word bits 31:8 (skip 
channels 01-11). 

TEST (OP 99) 

Test the status of the unit and return a re- 
sult descriptor. 

ERROR TERMINATION 

The end-of-page bit is set if the current de- 
scriptor does not specify a skip and there is a 
punch in channel 12 of the forms loop. The 
current descriptor is executed. 

BUFFERED PRINTER CONTROL NO. 2 

A result descriptor is returned when the 
printer buffer has been loaded. The print 
check error bit refers to the line of print asso- 
ciated with the prior descriptor. 



MAGNETIC TAPE 

TAPE SUBSYSTEM 

A magnetic tape subsystem can include up 
to four tape controls and up to sixteen mag- 
netic tape transports. Within a single tape 
subsystem, all magnetic tape transports must 
be used at the same speed; and all controls 
must be of the same type. 

TAPE EXCHANGES, FREE-STANDING UNITS 

A magnetic tape exchange is required when 
more than one control is used or more than 6 
magnetic tape transports are used. 

MAGNETIC TAPE EXCHANGE NO. 2 

This magnetic tape exchange provides the 
facility for either of two compatible magnetic 
tape controls to communicate with any of ten 
magnetic tape transports (all 7-track or all 9- 
track): 
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An exchange extension adapter is required 
for each group of two tape units. An adapter/ 
magnetic tape exchange is required for each 
ready-status cable (1 or 2) that is connected to 
an IOM. 

MAGNETIC TAPE EXCHANGE NO. 1 

This magnetic tape exchange provides the 
facility of communication between any of four 
NRZ magnetic tape controls and any of 16 free 
standing magnetic tape transports. 

The basic exchange is equipped for one con- 
trol unit and no tapes. 



TAPE EXCHANGE, CLUSTER UNITS 

A cluster is not connected to an external ex- 
change. It can include, as an option, 2x adapt- 
ers) enabling it to operate with two controls. 
A 2X master cluster provides 2x4 capability. 
The addition of a 2X slave provides 2x8 capa- 
bility. 

The controls of the same types (number of 
heads, and NRZ or PE) can operate with one 
master cluster (and its; matching slave). 

2 7-track NRZ, or 

2 9-track NRZ, only, or 

2 9-track PE only. 

Use, if any, of a cluster with two types of 
stations with the matching controls is permit- 
ted. The NRZ controls and stations must be 
treated as a separate sub-system from phase- 
encoded (P.E.) stations and controls associated 
with the same cluster (i.e., separate groups of 
unit designate numbers). 



CDL WORD FORMAT 





47 


43 


F39 


U 3 5 


3! 


27 


23 


19 


15 


11 


7 


3 


° 50 




46 


P 

42 




R38 


N34 


MI 

30 


sc 

26 


22 


18 


14 


10 


6 


2 


°49 


CO 

45 


de: 

41 


M 

A 37 


1 33 


29 


25 


21 


17 


13 


9 


5 


1 




4B 


44 


40 


T 

36 


T 

32 


28 


24 


20 


16 


12 


8 


4 






FIELD 



OP 


VAR 


Operation 


01 


iUVi 


Rewind 


02 


DUVC 


Read Forward 


03 


DUVC 


Read Backward 


04 


DUVi 


Erase 


06 


DUVi 


Write 


08 


DUNN 


Space Forward 


09 


DUNN 


Space Backward 


99 


iUii 


Test 



i = Ignored 

U = Unit Designate (LSD) 

NN = No. of Records (2 decimal digits; 00 spaces 100 
records) 

C = CRC Correction, if bit 27 is on (9 track NRZ only); 
track in error is in [26:3]. 

V4 = (Read/Write) = Special BCL translation in PC if bit 
30 is on (7 track EVEN parity only). 

V2.V1 (Read) = Maintenance variants if [29:2] ^ (ig- 
nored for PE tape). 

V2 (Write) = Write tapemark if bit 29 is on. 

V8 (Read) = Do not store information if bit 31 is on. 

VI (Rewind) = Unload tape if bit 28 is on (6A control 
only). 

V8 (Erase) = Backward pseudo-erase if bit 31 is on. 

D = Density and Parity 

800 556@ 200 1600* 



Density \ EVEN 2 

Parity / ODD 1 3 

@ = 7-Track Only. 

* = 9-Track PE Only. 

No. = Unit Selected Density. 



IOCW INFORMATION 



7-Track 






IOCW 


Bits 




COL 


Operation 


46 


44 


43 


42 4 


1 39 


Op Code 


Read Binary (6-bit to 6-bit) 





1 





( 


) 0/1 


02/03 


Read BCL into Int. BCL 





1 





1 1 


) 0/1 


02/03 


Read BCL into EBCDIC 





1 





1 


I 0/1 


02/03 


Read BCL into ASCII 


1 


1 





1 1 


) 0/1 


02/03 


Write Binary (6-bit to 6-bit) 











< 


1 X 


06 


Write BCL from Int. BCL 











1 ( 


1 X 


06 


Write BCL from EBCDIC 











1 1 


X 


06 


Write BCL from ASCII 


1 








1 ( 


1 X 


06 


Erase 


X 





1 


x ( 


) 


04 
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9-Track Operation 

Read Binary (8-bit to 8-bit) 
Read EBCDIC into ASCII 
Read ASCII into EBCDIC 
Write Binary (8-bit to 8-bit) 
Write EBCDIC from ASCII 
Write ASCII from EBCDIC 
Erase 



Both 



Rewind 

Space 

Write tapemark 

x = not used 



IOCW Bits 
46 44 43 42 41 






1 








1 


1 


1 








1 


1 


1 





1 


1 














1 


1 











1 


1 








1 


1 


X 





1 


X 


1 


X 





1 


X 


X 


X 


1 


1 


X 


X 


X 





X 


X 


X 



39 

0/1 
0/1 
0/1 

X 

x 
x 





1 

0/1 
x 



COL 
OP CODE 

02/03 
02/03 
02/03 
06 

06 
06 
04 

01 

08/09 

06 



RESULT DESCRIPTOR, UNIT ERROR FIELD 



Error Type 

Normal Termination by PC on Non-Read Operation 

Normal Termination by PC on Read Operation 

Long Block may be subsequently generated by IOM from 

final L1A address comparison with buffer length 

Short Block 

Memory-Access Error 

Beginning-of-Tape or End-of Tape 

Not Ready During Operation* 

Write Lockout or End-of-File 

Peripheral Interface Parity During Data Transfer* 

Memory Access Error on Read Operation** 

Peripheral Interface Parity in Initiate Phase* 

Bus Parity Error (System Interface Parity during Data 

Transfer*) 

System Interface Parity in Initiate Phase* 

Tape Positioning uncertain during Retry*** 

Parity Error 

Parity Error and End-of-Tape 

Parity Error and End-of-File 

Non-Present Option (Incorrect Density) 

Not Ready, Rewinding 

Blank Tape Timeout 

Blank Tape Timeout and Beginning-of-Tape 

CRC Correction Requested ( 9 track NRZ only; track in 

error is in Z4, Z2 and Zl (LSB); in Y2, Y4 and Y8 (LSB) 



*Model 6A Control only 
**Model 5A Control only 
***Generated by Software 

A test op returns the unit density in [11:2] of the RD to the MCP as follows: 
800 BPI, 1 = 556 BPI, 2 = 200 BPI, 3 = 1600 BPI. 



To 


From Device 


MCP 




0000 


800 




C20 


0801 




0401 




0081 


D00 


0101 


C80 


0109 


E80 


0201 


C40 


0481 


D20 


0489 


F20 


0881 


D10 


0889 


F10 


OC01 


- 


OC81 


D30 


OD81 


D80 


0E81 


D70 


2001 


C04 


4009 


E02 


8001 


C01 


8101 


C81 


Y001 


COZ (Z> 8) 


(Y 




odd) 
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OPERATIONS 

REWIND (OP 01) 

Rewind the designated tape unit. The control 
is released and a result descriptor returned af- 
ter rewind is initiated. 

READ OP 02 (FORWARD) OR OP 03 (REVERSE) 

Read a record from the designated tape unit. 
The operation is terminated by detection of an 
interrecord gap. Information transfer is termi- 
nated after reading the specified number of 
words or by sensing a:n internal DSU error. 

ERASE (OP 04) 

Erase in the forward direction on the desig- 
nated tape unit. The operation is terminated 
by erasing the number of words specified. No 
memory cycles are used. 

WRITE (OP 06) 

Write a record on the designated tape unit. 
The operation is terminated by writing the 
specified number of words or a delimiter in the 
data stream. 

WRITE TAPE MARK (OP 06) 

Write a tape mark record on the unit desig- 
nated, when V = 2. 

SPACE (OP 08 (FORWARD): OP 09 (REVERSE) 

Space 1 to 100 records as specified by the 
BCD value of NN of the CDL word. If bits NN 
are all 0's, space 100 records. 

TEST (OP 99) 

Test the status of the designated unit and 
return a result descriptor. 

BCL ALPHA OPERATION (7-TRACK TAPE WITH EVEN 
PARITY) 

When the 6-bit frame size and even parity 
are selected, BCL internal code is converted to 
BCL code on write, and BCL code is converted 
to BLC Internal Code on read. The BCL "?" 
code is written (001111). 

All above operations are performed by the 
control. 

EXCEPTION CONDITIONS 

End of tape does not terminate an operation. 
The end-of-tape bit is set in the result descrip- 
tor after the operation is completed. 

On read operations, when a vertical parity 
error is detected and the 6 bit frame size is se- 
lected, a BCL "?" code is stored by the control 
in memory in place of the code in error. 

CRC CORRECTION (9-TRACK, 800 BPI ONLY) 

CDL bits V enables CRC correction. The 3 
LSB's define the track: to be corrected (0-7). 
The parity track cannot be corrected. 



PAPER TAPE PUNCH 

PAPER TAPE PUNCH CONTROL 

The B 9220 Paper Tape Punch is capable of 
punching a standard paper tape format in ei- 
ther BCL or Baudot code. The punch accom- 
modates 5-, 6-, or 8-channel tape at a 
maximum rate of 100 characters per second, 
punching 10 characters to the inch. Standard 
tape widths of 11/16, 7/8, and 1 inch may be 
used in either the oiled paper tape, metalized 
mylar tape, or laminated mylar tape. 

Each paper tape I/O control, reader or 
punch, can accommodate only one paper tape 
unit. The controls are the small-size controls 
which can be set into a PCC cabinet as either 
a right hand or a left hand control. 

CDL WORD FORMAT 





47 


43 


39 


35 


F31 


27 


23 


19 


15 


11 


7 


3 




50 




46 


P 

42 


38 


34 




R30 


26 


22 


18 


14 


10 


6 


2 


4 9 


CO 

45 


DE 

41 


37 


35 


M 

A 29 


25 


21 


17 


13 


9 


5 


1 




48 


44 


40 


361 


32 


T 

28 


24 


20 


16 


12 


8 


4 






FIELD 
OP VAR 

48 iiVi 

49 iiii 



ADDR 



99 



mi 



Operation 

Write 
Punch 
Leader 
Test 



i = Ignored 

V = Format: 

= 7 bits, even parity generated by control 
1=6 bits, odd parity generated by control 
2=8 bits, no parity 



IOCW INFORMATION 










IOW Bits 


CDL 


Operation 


46 43 42 


41 


OP Code 


Write Binary (6-bit from 6-bit) 








48 


Write (8-bit from 8-bit) 





1 


48 


Write EBCDIC from ASCII 


10 


1 


48 


Write ASCII from EBCDIC 


10 1 


1 


48 


Write BCL from Int. BCL 


1 





48 


Write BCL from ASCII 


10 1 





48 


Write BCL from EBCDIC 


1 


1 


48 


Punch Leader 


1 





49 



RESULT DESCRIPTOR, UNIT ERROR FIELD 

To MCP From Device Error Type 

0101 C80 Low Tape 

0401 C20 Short Block 
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OPERATIONS 

WRITE (OP 48) 

Punch one record on the paper tape punch. 
The operation is terminated by punching the 
specified number of words or by punching a 
control code. BCL Internal Code, ASCII, or 
EBCDIC is converted to BCL code by transla- 
tors in the IOM. BCL code is converted to BCL 
paper Tape Code by a translator in the punch. 
If bits 31:4 in the CDL word contain a zero, 
the eighth bit of the character is ignored, and 
an even parity bit is sent on the eighth line 
from the control to the paper tape punch. Odd 
parity is punched on the paper tape. 

If bits 31:4 in the CDL word contain a one, 
the EBCDIC/BCL translator is enabled. The 
control will terminate the operation when the 
delimiter (1000 0000) is detected. The delimiter 
is not sent to the punch. The seventh bit re- 
ceived from memory is ignored, a zero bit is 
forced on the seventh line, and an odd parity 
bit is sent on the eighth line. The BCL/BCL 
paper tape code translator in the paper tape 
punch is enabled to complete the data trans- 
fer. Odd parity is punched on the paper tape. 
If bits 31:4 in the CDL word contain a two, 
the control sends all eight bits received from 
memory to the paper tape punch. Parity is nei- 
ther generated not sent. 

PUNCH LEADER (OP 49) 

Punch the specified number of characters. 
When the 8-bit frame size is selected, all one 
characters are punched for each character 
spaced. When the 6-bit frame size is selected, 
each character spaced is an all zeros charac- 
ter. 



TEST (OP 99) 

Test the status of the unit and return a 
suit descriptor. 



re- 



If a memory parity error is encountered dur- 
ing a write operation, the operation is termi- 
nated without punching any erroneous charac- 
ters. 

PAPER TAPE READER 

PAPER TAPE READER CONTROL 

The B 7120 Paper Tape Reader Control is 
used with the paper tape reader. The B 9120 
Paper Tape Reader is capable of reading 
punched paper tape at a rate of 1000 charac- 
ters per second and metalized mylar tape or 
fanfold tape at a rate of 500 characters per 
second. Baudot and BCL to EBCDIC code 
translation is automatic. All other codes are 
read directly into memory and may be trans- 
lated programmatically. The reader can ac- 
commodate 5-, 6-, or 8-channel tape as se- 
lected by the operator. Tape widths of 11/16, 7/ 
8, or 1 inch are interchangeable. 

CDL WORD FORMAT 





47 


43 


39 


35 


F31 


27 


23 


19 


. 15 


11 


7 


3 


°50 




46 


P 

42 


38 


34 



R30 


26 


22 


. 18 


'14 


i 
10 


6 


2 


49 


CO 

45 


DE 

41 


37 


3-3 


M 

A 29 


25 


21 


J7 


13 


9 


5 


1 




48 


44 


40 


36 


32 


' 28 


24 


20 


16 


12 


8 


4 






FIELD 
OP VAR 

40 iiVi 



41 
43 
47 
99 



1111 
iiii 



EXCEPTION CONDITIONS 

When the number of words specified are not 
written due to termination by the punch, the 
incomplete record bit is set by the control in 
the result descriptor. 

IOCW INFORMATION 



1111 



Operation 

Read 

Space Forward 

Space Backward 

Rewind 

Test 



i = Ignored 
V = format: 

= 7 bits (odd parity) 

1 = BCL/EBCDIC - 6-bit (odd parity) 

2 = 8 bits (no parity) 



IOCW Bits 



Operation 

Read Binary (6-bit into 6-bit) 

Read (8-bit into 8-bit) 

Read EBCDIC (EBCDIC to 

ASCII) 

Read BCL (Ext. BCL to Int. BCL) 

Read BCL (BCL to ASCII) 

Read BCL (Ext. BCL to EBCDIC) 

Read ASCII (ASCII to EBCDIC) 

Space Forward 

Space Backward 

Rewind 



46 




1 



1 



1 







43 











1 

1 
1 



42 





1 
1 
1 
1 







41 



1 
1 




1 
1 







39 











1 
1 



CDL 

OP Code 

40 
40 

40 

40 
40 
40 
40 
41 
43 
47 
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RESULT DESCRIPTOR, UNIT ERROR FIELD 

To From Device Error Type 
MCP 

0081 DO0 Memory-Access Error 

0101 C08 Beginning-of-Tape or End -of -Tape 

0281 D40 Parity Error 

0401 C20 Short Block 



OPEE RATIONS 

READ (OP 40) 

Read one record from the paper tape reader. 
The operation is terminated by reading the 
specified number of words, reading a control 
code, or encountering end of tape. BCL code is 
converted to BCL Internal Code, ASCII, or 
EBCDIC by translators in the IOM. The read- 
er parity-error line is monitored. 

NOTE 
Control codes are defined by 
switches on the paper tape reader. 

If bits 31:4 in the CDL word contain a zero, 
only the least significant seven bits of the 
eight bits received from the reader, together 
with a high order zero bit are sent to the IOM 
for possible translation. 

If bits 31:4 in the CDL word contain a one, 
the eight bits received from the reader are 
transferred to the IOM via the BCL/EBCDIC 
translator; however, the translator will ignore 
the two most significant bits. The BCL paper 
tape code/BCL internal translator in the read- 
er is enabled. 

If bits 31:4 in the CDL word contain a two, 
the eight bits received from the reader are 
transferred to the IOM. 

SPACE FORWARD (OP 41) 

Space forward the number of words specified 
unless stopped by end of tape or a control 
code. 

SPACE BACKWARD (OP 43) 

Space backward the number of words 
specified unless stopped by beginning of tape 
or a control code. 

REWIND (OP 47) 
Rewind to beginning of tape. 

TEST (OP 99) 

Test the status of the unit and return a re- 
sult descriptor. 

EXCEPTION CONDITIONS 

When the number of words specified is not 
read or spaced due to termination by the read- 
er, the incomplete record bit is set by the con- 
trol in the result descriptor. 



Parity errors and memory access errors are 
reported at the end of an operation. 

In the event of a memory access error and 
the termination of an operation by word count 
or end of tape, the number of characters 
spaced is not known. Special-error retry proce- 
dures may be required. 

SINGLE LINE CONTROL 

BURROUGHS TERMINAL COMPUTER MODEL 
TC500 

BURROUGHS INPUT AND DISPLAY TERMINAL 
MODEL B 9352 

Up to 8 of the above units in any combina- 
tion can be serviced. It is required that the 
TC500 have the proper "firmware" micropro- 
gram to operate in accordance with the com- 
munications procedures outlined below. The 
single line control, figure IV-3-4, performs the 
following functions: 

a. Message heading insertion for messages 
transmitted to a terminal. 

b. Message heading deletion for messages 
received from the terminal. 

c. Generation of vertical and longitudinal 
parity (even). 

d. Checking of vertical and longitudinal par- 
ity (even). 

e. Code conversion between EBCDIC and 
ASCII (7-bit). 

f. Generation of input request interrupts. 
Read and write message formats are defined 

in figures IV-3-5 and IV-3-6. 

CDL WORD FORMAT 
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I/O MODULE 
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NOTE: 

MAXIMUM CABLE LENGTH BETWEEN THE SINGLE LINE CONTROL AND A TERMINAL UNIT IS 50 FEET. 
THE MESSAGE FORMAT IS A SUBSET OF THE BURROUGHS COMMUNICATION PROCEDURE STANDARD, 
STANDARD 1284-9006. DATA TRANSMISSION IS ASYNCHRONOUS WITH EACH CHARACTER 
TRANSMITTED CONSISTING OF 10 BITS AS FOLLOWS: A "0" START BIT, 7 INFORMATION BITS 
(LEAST SIGNIFICANT BIT FIRST), AN EVEN PARITY AND A "l" STOP BIT. 

Figure IV-3-4. Single Line Control Configuration 



RESULT DESCRIPTOR, UNIT ERROR FIELD 
To From Device Error Type 

MCP 



0009 


EOO 


Not Ready to Receive 


0081 


D00 


Memory-Access Error 


0281 


D40 


Parity Error 


0401 


C20 


Control Message 


0801 


CIO 


Overflow 


0881 


D10 


Bus Parity Error 


8001 


C01 


Timeout 



A hard-wired plug board on the control de- 
termines what device type information the 
test op returns in bits [14:3] of the RD. The 
MCP uses this information to set the default 
screen width for displays: 2 = 80 characters 
(TC500), 1 or 4 = 40 characters (CONRAC) = 
device not present. 

OPERATION 

READ (OP 32) 

Read an input message from the designated 
terminal unit until an "End of Text" character 
is detected or until the area descriptor word 
count is exhausted, whichever comes first. An 
ASCII & EBCDIC translator is located in the 
peripheral control. 

The IOM either stores the data as received 
or translates to ASCII. 



NOTE 
Each of the 8 terminals which can 
be connected to a Single Line Con- 
trol is assigned a system unit des- 
ignate number. The unit desig- 
nates must be sequential. 

WRITE (OP 34) 

Send a message to the designated terminal 
unit until an "End of Text" character is de- 
tected in the message or until the area de- 
scriptor word count is exhausted, whichever 
comes first. The IOM either transmits data as 
received, or does an ASCII to EBCDIC trans- 
lation. An EBCDIC to ASCII translator is en- 
abled in the control. 

TEST (OP 99) 

Return a result descriptor indicating the 
type of the designated terminal unit. If no 
type bit is returned, it means there is no ter- 
minal unit connected to the Single Line Con- 
trol with that unit designation. 

SINGLE LINE CONTROL 

One adapter is required for each terminal 
unit connected to a Single Line Control. This 
adapter is comprised of one level changer card 
and one cable. 
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ENABLE CTS (CLEAR TO SEND) 



NO RESPONSE 
OR INVALID 



EOT 
v 



EOT 

TIME OUT R. D. 



* 

EOT 

NOT READY R.D. 



STX 

t 



(TEXT) 

ETX 

BCC 

I 

I 



r 

ACK 



NO ERROR 



J~ ERROR 

NAK (DISABLE CTS) 



r 



DATA PARITY ERROR R.D. 



NO RESPONSE 
OR INVALID 



EOT 



DISABLE CTS 

EOT 

TIME OUT R.D. 
DISABLE CTS 



f 



EOT 

I/O FINISHED R.D 



note: 

1. STX IS NOT STORED IN THE B7700 MEMORY 

2. THE NAK SENT TO THE TC500 OR B 9352 IN THE EVENT OF AN ERROR, 
CONDITIONS THE TC500 OR B 9352 TO RETRANSMIT THE SAME MESSAGE 
IN RESPONSE TO THE NEXT READ COMMAND. 

Figure IV-3-5. Read Message Format TC500 and B 9352 



Data transmission rates of either 1200 or 
2400 bits per second can be selected by imple- 
mentation of the appropriate adapter in the 
peripheral control. The adapters used for this 
purpose are Adapter-SLC Timer 2400 and 
Adapter-SLC Timer 1200. 

Either of these pluggable adapters may be 
installed by a field engineer. The transmission 
line rate must be the same for all terminals on 
the same Single Line Control. The rate for the 
TC500 is limited to 1200 bits per second. 



Plug-ons with jumpers in the peripheral con- 
trol are required to identify the terminal de- 
vice type associated with each of the 8 possible 
terminal units. If no device is connected to a 
particular interface, the corresponding jumper 
should be removed from the plug-on. See In- 
structions - Peripheral Control Special No. 
1639 7049 for details on jumper locations. 

The control receives the receive ready status 
from the terminals and sends this information 
to the appropriate status vector in the IOM 
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EOT 

ENQ 



ENABLE CTS (CLEAR TO SEND) 



*- EOT 

TIME OUT R.O. 



-* EOT 

NOT READY R.D. 



(I) STX - 

I 

I 

(TEXT) 

I 



i 
ETX 
BCC (OPTIONAL) 



* EOT 

TIME OUT R.D. 



*- DATA PARITY 
ERROR RD. 



* EOT 

I/O FINISHED R.D. 



NO RESPONSE 
OR INVALID 



J 



NO RESPONSE 
OR INVALID 



t 



I. STX IS GENERATED BY THE SINGLE LINE CONTROL 



* DISABLE CTS 

40199 



NAK 



ACK 



NAK 



ACK 
(DISPLAY DATA) 



Figure IV-3-6. Write Message Format TC500 and B 9352 
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via a belted coaxial cable. Input request inter- 
rupts initiated by the terminals are sent via 
individual coaxial cables (1 to 8) to the related 
IOMS status change vector. 

The control contains a one character buffer 
which receives and sends bit serial informa- 
tion from/to the terminal unit. Transfer of 
data from and to the IOM is character serial 
(8 bits). 

The control recognizes the "ETX" code 
(0000011) in an input message which is trans- 
lated and transferred to the IOM as 0000 0011. 
Detection of the end of text code terminates 
the input and stores a result descriptor. 

The control recognizes the "ETX" code (0000 
0011) in an output message. The end of text 
code terminates the output and a result de- 
scriptor is stored. 

If the terminal is in the transmit mode when 
the control is initiated to do an output, a re- 
sult descriptor is returned with the not-ready 
bit set. 

There are two delay multi's in the Single 
Line Control. One multi (DLTO) monitors the 



line "Turn around" time such that if a termi- 
nal does not respond within a time limit, the 
time out flip-flop (TMOF) is set and a result 
descriptor generated. If an invalid response is 
received, the same result occurs without wait- 
ing for the multi to time out. The second multi 
monitors the time elapsed between characters 
being received from a terminal. If excessive 
time elapses, the multi (CHTO) times out, set- 
ting the time out flip-flop (TMOF) and a result 
descriptor is generated. 

On a read, if the Single Line Control has not 
gained access to the IOM in time to store a 
character before the next character is received 
from the terminal, a memory access error is 
flagged in the result descriptor, the character 
is lost, and reading continues. On a write, if 
the Single Line Control has not gained access 
to the IOM to fetch another character by the 
time required to maintain line transmission 
rates, a memory access error is flagged in the 
result descriptor, an all zeros (NULL) code is 
sent to the terminal in place of the character, 
and writing continues. 
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CHAPTER V 
MEMORY SUBSYSTEM 



GENERAL DESCRIPTION OF THE MEMORY SUBSYSTEM 



INTRODUCTION 

The B 7700 Memory Subsystem provides the 
main storage for the B 7700 Data Processing 
System. The memory subsystem stores or sup- 
plies words of information as directed by ei- 
ther of two types of requestor: a cnetral proc- 
essor or an input/output processor. 

A B 7700 Memory Subsystem is a modular 
configuration of one to eight memory modules 
coupled through a memory requestor switch/ 
interlock network to a maximum of eight 
memory requestors. (See figure V-l-1.) The 



memory subsystem can service each requestor 
in the same manner so that any operation per- 
formed for one requestor may also be per- 
formed for any other requestor. 

A memory module consists of a memory con- 
trol module (MCM) cabinet which controls ei- 
ther one or two memory storage cabinets 
(MSC). The MCM controlling one MSC is iden- 
tified as a 2-MSU memory module. The MCM 
controlling two MSC's is identified as a 4-MSU 
memory module. Each MSC contains: two inde- 
pendently addressable 2-1/2 D 2-wire, 1.5-us., 
core memory storage units (MSU). Each MSU 
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Figure V-1-1. B 7700 Memory System Modularity Diagram 
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consists of a memory storage module (MSM) 
with a storage capacity of 65,536 words 
(393,216 bytes) a memory logic module (MLM) 
and an independent memory power supply 
unit (MPU) for each MSU. (See figure V-l-2.) 

MEMORY CAPACITY 

A B 7700 Memory System may be built with 
various combinations of the two configura- 
tions of memory modules to achieve the de- 
sired total memory capacity. Table V-l-1 lists 
the possible combination of memory sizes. 

MINIMUM MEMORY SIZE 

The minimum memory size is one 2-MSU 
memory module of 131,072 words (786,432 
bytes). This would be one MCM controlling one 
MSC containing two MSU's (65,536 words 
each). For optimum system performance the 
minimum B 7700 Memory Subsystem recom- 
mended is two 4-MSU memory modules. 

MAXIMUM MEMORY SIZE 

The maximum memory size is 1,048,576 
words (6,291,456 bytes) which may be packaged 
as: 

a. Eight 2-MSU modules 

b. Four 4-MSU modules 

c. A comination of 2-MSU and 4-MSU mod- 
ules, the total of which equals 1,048,576 words. 



MSU RECONFIGURATION 

The B 7700 Memory Subsystem is designed 
with high reliability to minimize the occur- 
rence of failure. Extensive error detection and 
reporting logic permits early detection and 
definition of failures. Automatic correction of 
single-bit parity errors minimizes interruption 
to the system. The modular design, separate 
power supplies, and independent interface con- 
cept permits soft reconfiguration. In case of 
an MSU failure, the system can be manually 
or programmatically reconfigure as follows: 

a. The four-MSU memory module will be re- 
configured to operate with only two MSU's 
available to the MCM as the cabinet contain- 
ing the failed MSU becomes unavailable to the 
MCM. 

b. The two-MSU memory module will be re- 
configured to operate with only one MSU 
available to the MCM. 

ADDRESS ALLOCATION 

There is no specific assignment order within 
the system for particular MCM configurations. 
Memory module address range assignments 
are based on system requirements and are as- 
signed through use of the memory limits word. 
For example, any MCM in the system can be 
assigned the lower (memory zero) address 
range by setting the memory limits register. 



Table V-1-1. B 7700 Memory Module Combinations 





Memory Size 


Memory Module 




Memory Module 








Quantity 




Combination 


Words 


Bytes 


2-MSU 
Type 


4-MSU 
Type 


MCM 


MSU 


131,072 


786,432 


1 


- 


1 


2 


262,144 
262,144 


1,572,864 
1,572,864 


2 


1 


2 
1 


4 
4 


393,216 
393,216 


2,359,296 

2,359,296 


3 

1 


1 


3 
2 


6 
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524.288 
524,288 


3,145,728 
3,145,728 
3,145,728 


4 
2 


1 
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4 
3 
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8 
8 
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655.360 
655.360 
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3,932,160 
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1 
2 


5 
4 
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10 
10 
10 
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786,432 
786,432 
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2 
3 


6 
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5,505,024 
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2 
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14 

14 
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1,048,576 
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6,291,456 
6,291,456 
6,291,456 
6,291,456 
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Figure V-1-2. B 7700 Memory Subsystem 



SUBSYSTEM ALLOCATION 

The memory capacity can be manually or 
program matically allocated into subsystems 
with respect to designated requestors. For ex- 
ample, MCM's and 2 can be dedicated to re- 
questors and 7 while MCM's 1 and 3 can be 
dedicated to requestors 1 and 6. 

CLOCK RATE AND READ ACCESS TIMES 

The B 7700 Memory Subsystem operates at a 
clock rate of 8.13874 megaHertz. Effective 
read access time for the MCM is as follows: 

a. Single word access is 1.720-us or 0.297-us 
per byte. 



b. Two word access is 1.843-us, or 0.922-us 
per word, or 0.154-us per byte. 

c. Four word access is 2.089-us, or 0.522-us 
per word, or 0.087-us per byte. 

MULTIPLE-WORD TRANSFER (PHASING) 

In a multiple-word transfer (known as phas- 
ing) words are transferred in bursts of up to 
four; one word is transferred at each clock cy- 
cle. 

The maximum number of words which can 
be phased by the MCM is limited to the num- 
ber of MSU's being controlled by the MCM. 
(For example, a four MSU configuration can 
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phase tour words, and a two MSU configura- 
tion can only phase two words.) If the re- 
quested address is less than eight words from 
the upper address limit of the MCM, the mem- 
ory operation is limited to a single-word trans- 
fer. 

These phasing limits do not have to be taken 
into consideration when a requestor sends a 
memory request. The requestor simply re- 
quests the desired number of words to be 
transferred, and then decreases the number of 
words each time a memory transfer is com- 
pleted. If at the end of the operation the word 
count is not equal to zero, then another re- 
quest is made until all the words are trans- 
ferred. 

MSU PHASING 

A 4-MSU configuration is interfaced so that 
four consecutive addresses fall in four differ- 
ent memory storage units. (See figure V-l-3.) 
The effect is that multiple word transfers 
(phasing) occur in groups of four words each, 



one at each successive clock. The MCM reads 
the first word from the MSU defined by the 
MSU selector bits of the memory address and 
sends it to the requestor. 

As shown in figure V-l-3, the least 
significant 2 bits (1:2) of the memory address 
are identified as the MSU select bits. The de- 
coding of these bits is as follows: 



2 LSB's 


MSU Selection 


00 


MSU 1 


01 


MSU 2 


10 


MSU 3 


11 


MSU 4 



The following 16 bits (17:16) are identified as 
the MSU Address bits which specify the mem- 
ory location to be accessed. These bits repre- 
sent the actual memory address sent to the 
MSU. The remaining 2 bits (19:2) are identified 
as the MCM Select bits. These bits determine 
whether the specified address exists within 
the MSU's assigned to the MCM. 



MEMORY ADDRESS 




15 



11 i 



MSU 
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10, 



ADDRESS 
,3 + 9 + 

12| 81 




MSU#1 (LSB'S=00) 


(LLA*+00000) 


(LLA+00004) 






(LLA+3FFF8) 


(LLA+3FFFC) 



MSU #2 (I 


.SB'S=01) 


(LLA+00001) 


(LLA+00005) 






(LLA+3FFF9) 


(LLA+3FFFD) 



MSUff3 (LSB'S=10) 


(LLA+00002) 


(LLA+00006) 






(LLA+3FFFA) 


(LLA+3FFFE) 



MSU #4 (LSB'S=11) 


(LLA+00003) 


(LLA+00007) 






(LLA+3FFFB) 


(LLA+3FFF)** 



f LLA= LOWER LIMIT ADDRESS 

MLLA+3FFFF) = UPPER LIMIT ADDRESS FOR 4-MSU CONFIGURATION 

Figure V-1-3. Four MSU "Phasing" Address Layout 
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For a 2-MSU configuration (see figure V-l-4), 
the least significant bit (0:1) of the memory 
address is identified as the MSU Selector bit. 
When this bit equals 0, either MSU 1 or MSU 
3 is selected; when this bit equals 1, either 
MSU 2 or MSU 4 is selected. A 2-MSU 
configuration is interfaced so that 2 
consecutive addresses fall in 2 different 
memory storage units. 
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When information is passed from a reques- 
tor to an MCM, the requestor adds a parity bit 
which produces odd parity on the resultant 52- 
bit word being transferred. The MCM checks 
the word it receives for odd parity to verify 
that an error was not made during transmis- 
sion. 

When an MCM receives a 52-bit word from a 
requestor, the MCM adds seven bits of error 
correction code and adds another bit for main- 
taining odd parity on the overall 60-bit word. 
The MCM then sends the 60-bit word to the 
MSU. If a word should be accidentally altered 
while residing in an MSU, the seven check bits 
in conjunction with the overall parity bit al- 
lows for the detection of the error and provide 
a means for the automatic correction of errors 
in which a single bit has been altered. The 
MCM then sends the original 51-bit word to 
the requestor. 
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Figure V-1-4. Two MSU "Phasing" 
Address Layout 

For a single-MSU configuration (see figure 
V-l-5), the least significant 16 bits (15:16) rep- 
resent the actual memory address sent to the 
MSU. The remaining 4 bits (19:4) are identified 
as the MCM Selector bits. 



MEMORY OPERATIONS TIMING 

Timing diagram figures V-l-6, V-l-7, and V- 
1-8 show a general sequence of the major 
memory operations. 

WORD FORMATS 

All words used by the B 7700 Mainframe 
System are 52 bits in length. The 52-bit word 
consists of 48 bits of information, three tag 
bits, and an overall parity bit. (See figure V-l- 
9.) 



SINGLE MSU 
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(LLA+FFFE) 
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( LLA = LOWER LIMIT ADDRESS 
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FOR 1 MSU CONFIGURATION 



Figure V-1-5. Single MSU Address Layout 
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Figure V-1-6. Single Word Read or Write Operation, Timing Diagram 
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Figure V-1-7. Four Word Read Operation, Timing Diagram 
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•MEMORY'S CLOCK IS OUT OF PHASE WITH REQUESTOR'S CLOCK 
**THERE IS A .0675 USEC CABLE DELAY BETWEEN MCM'S AND REQUESTOR'S INTERFACE 



Figure V-1-8. Four-Word Write Operation, Timing 
Diagram 
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Figure V-1-9. Data Word Transfer Between Requestor and Memory 



MCM CONTROL WORD 

At the start of every memory operation, an 
MCM control word is transmitted from the re- 
questor to the memory control module. The 
control word format, bits and fields as re- 
ceived at the memory control module are de- 
scribed below. Table V-l-3 lists the valid 
operation codes for the MCM. 



PARITY 

' 51 


R/W 

47 


FB 

43 


39 


35 


31 


27 


23 


19 


15 


11 


7 


3 


T 5 


TYPE 

46 


RIL 

42 


aa 


34 


AD 

30 


)RE 

26 


ss 

22 


18 


14 


10 


6 


2 


A 

G 49 


SPEC 

45 


MLL 

41 


37 


33 


29 


25 


21 


LSB 

17 


13 


9 


MSB 

WORD 1 


48 


PRO- 
TECT 


40 


MSB 

36 


32 


28 


24 


20 


RES- 
IDUE 


1? 


B 


LENGTH 

4 LSB 



Field 
PARITY 

TAG 

R/W 

TYPE 

SPEC 
PROTECT 



Bits 

51:1 

50:3 
47:1 
46:1 

45:1 



FB 



RIL 



MLL 



ADDRESS 



RESIDUE 



WORD 
LENGTH 



Description 

The requestor generates odd parity 
for the 52-bit control word. 

The Tag bits are not used in the 
control word. 

R/W bit: = read (fetch) operation; 
1 = write operation. 

The Type bit is only set for fail 
word fetch and N-word protected 
write operations. 

The SPEC (specifier) bit indicates 
either a single word or multi-word 
operation: = multi-word operation; 
1 = single word operation. 

44:1 The protect bit, when "1" indicates 
that a protected-write operation is 
to be performed. Protected write 
only allows the write operation to 
be performed when bit 48 of the 
original memory word is off. When 
bit 48 is on, the write operation is 
terminated and the contents of the 
original memory word are not 
changed. 

43:1 The FB (flashback) bit, when a "1" 
indicates that the original contents 
of the memory location are to be 
transferred to the requestor. 

42:2 The RIL (requestor inhibits load) bit 
is used to specify that a load 
requestor-inhibit operation is to be 
performed. 

41:1 The MLL (memory limits load) bit is 
used to specify that the upper and 
lower address registers and the 
MSU available register are to be 
loaded. 

40:4 Unused. 

36:20 The address bits specify the 
starting-memory address of the 
memory operation. 

16:2 The address residue bits indicate 
the residue value of the 20-bit 
memory address within the control 
word. 

5:6 The word-length bits indicate the 

number of words to be transferred 
during multi-word operations. 



MCM FAIL WORD 

The MCM fail word contains all pertinent in- 
formation necessary to identify a hardware 
failure. The fail word information is locked in 
a 52-bit fail register until a fetch-the-fail reg- 
ister operation request is made by the reques- 
tor or a manual clear operation is performed. 
The MCM sends a fail 1 interrupt signal to the 
requestor when an irrecoverable error has oc- 
curred or a fail 2 interrupt signal when a one- 
bit error has occurred. If one of the bits in a 
memory word was incorrect, the specific bit is 
corrected by the MCM. The correct memory 
word is then sent to the requestor together 
with a fail 2 interrupt signal which allows the 
requestor to record the error and also to con- 
tinue processing with correct data. The for- 
mat, bits, and fields of the MCM fail word are 
described below: 
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Field Bits Description 

D.I 48:1 The delayed interrupt (D.I) bit, 

when set, indicates that an internal 
error was detected during the 
previous memory cycle and had 
occurred after the requestor 
operation complete (ROC) signal was 
sent to the requestor. This interrupt 
does not occur until the next 
memory operation is performed. 

R/W 47:1 The R/W bit indicates that either a 

read or write operation was being 
executed when the error was 
detected. (Read = 0; write = 1). 

MSU 46:2 The MSU AV (MSU available) field 

AV indicates the number of MSU's in 

use by the MCM when the error 
was detected. The field indication is 
as follows: 



No MSU is available 
One MSU is available 
Two MSU's are available 
Four MSU's are 
available 



MCM 44:4 The MCM number is preassigned 

NO. hardware number (from thru 15) 

that is given to each MCM to 
identify the specific MCM with the 
error condition. 
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40:3 



37:6 



31:20 



CWP* 



11:1 



The REQ CHNL NO. (requestor- 
channel-number field) contains the 
number of the requestor who was 
using the MCM when the failure 
occurred. This field is not locked in 
the fail register if detection of a 
one-bit error occurs. 

The error bit number field is only 
valid when bit 5 (1-bit error) is 
set. This field is the binary number 
of the bit that failed in memory. 

The error-address field contains the 
address of the location that was 
being accessed if a one-bit or two- 
bit error occurred. The address is 
related to one-bit or two-bit errors 
as follows: 



Error Indication 
2-Bit 1-Bit 

1 

1 
1 1 



Error Address 

Belongs to: 

1-Bit Error 
2-Bit Error 
1-Bit Error 



The CWP (control word parity) bit 
when set, indicates that the MCM 
has detected incorrect parity on the 
control word received from the 
requestor. 



IOP* 10:1 The IOP (illegal operation) bit, when 

set, indicates that the MCM has 
detected an illegal operation in the 
control word. These illegal 
operations are as follows: 

(1) Word length = 

(2) Single-word operation word 
length greater than 1 

(3) Special-request strobe is not sent 
by the requestor when either 
memory-limits load or requestor- 
inhibit load is to be performed. 

(4) Illegal-operation code (refer to 
table V-l-3). 

WRA* 9:1 The WRA (wrong address) bit, when 

set, indicates that the address in 
the control word did not fall within 
the upper and lower address limits 
assigned to the MCM. 

DWP* 8:1 The DWP (data-word parity) bit, 

when set, indicates that a data 
word containing even parity was 
received from the requestor. 

STB* 7:1 The STB (data-strobe) error bit 

when set, indicates that the MCM 
has detected an error in the 
number of words sent by a 
requestor during a multiple word 
transfer. 



Table V-1-3. Valid Operation Codes for the MCM 

R/W TYPE SPEC 

Operation 47 46 45 

1 






Fetch, Single word 
Fetch, Multiple word 
Fetch, Fail register 

Write, Single word overwrite 1 

Write, Multiple word overwrite 1 

Write, Single word overwrite with flashback 1 

Write, Single word protected write 1 

Write, Single word protected write flashback 1 

Write, Multiple word protected write 1 

Load, Requestor inhibits 1 

Load, Memory limits 1 
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2B* 



IB* 



INT* 



INT 

ERR 

TYPE 



6:1 A 2B (2-bit) error, when set, 

indicates that the MCM detected a 
(non-correctable) multiple bit error 
from the MSU. If this error occurs, 
the data transfer to the requestor 
is completed. 

5:1 A IB (1-bit) error, when set, 

indicates that the MCM detected a 
(correctable) 1 bit error from the 
MSU. 

4:1 The INT (internal) error bit, when 
set, indicates an error occurred 
within the MCM or MSU. This error 
is further defined by bits 3:4. 

3:4 The internal error type bits define 
the type of internal error identified 
by bit 4. The internal error bits are 
defined as follows: 



Fail Word Bit 
3210 

0110 



0111 



1000 



Error Type 



Fall Word Bit 
3210 

0000 MSU Available - 
indicates that 
MSU power was 
interrupted. 

0001 Read Available - 
indicates that the 
MSU has failed to 
respond with a 
Read Available 
signal during a 
read operation. 

0010 Checker/Generator 

- indicates that an 
error had occurred 
in the MCM 
Parity Checker/ 
Generator (data) 
circuits. 

0011 Address Residue - 
indicates that 
either a bad 
address residue 
was detected in 
the Control Word 
received from a 
requestor, or was 
generated by the 
MCM Address 
Counter during a 
multiple word 
transfer operation. 

0100 MSU Parity Error 

- indicates that 
the MSU detected 
a parity-error in 
the address and 
controls received 
from the MCM. 

0101 Parity Generator 
(address and 
control) Error - 
indicates that an 
error occurred in 
the MCM Parity 
Generator circuits. 



Error Type 



Data timer 
Failure - indicates 
that a failure 
occurred in the 
Data Timer 1-4 
circuits. 

Data Transfer 
Control (DTC) 
Failure - indicates 
that a failure 
occurred in the 
DTC circuit. 

MSU Availability 
Failure - indicates 
that an illegal 
MSU Availability 
configuration 
exists. The legal 
configurations of 
MSU Availability 
are as follows: 

4321 

0001 

0010 Single- 

0100 MSU 

1000 Configuration 



* Fail 1 interrupt condition 
**Fail 2 interrupt condition 



0011 
1100 

1111 



Two-MSU 
Configuration 

Four-MSU 
Configuration 



MEMORY ADDRESS LIMITS WORD 

The Memory Address Limits word changes 
the MCM and MSU configuration to reflect 
the number of MSU's available to the MCM as 
well as the upper and lower address limits. 
This word follows the special request signal 
and the memory address limits load word dur- 
ing memory control operations between the 
MCM and requestor. The format, bits, and 
fields of the Memory Address Limits are de- 
scribed below: 
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Field Bits Description 

PARITY 51:1 The MCM examines the memory 

address limits word for odd parity. 

50:35 Unused 

ALL 15:6 The address lower limit is the most 

significant 6 bits of the lowest 20- 
bit memory address available to this 
MCM. 
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9:6 The address upper limit is the most 
significant 6 bits of the highest 20- 
bit memory address available to this 
MCM. 

3:1 When AV4 is a "1", the MSU 

designated MSU4 is available to this 
MCM. 

2:1 When AV3 is a "1", the MSU 

designated MSU3 is available to this 
MCM. 

1:1 When AV2 is a "1", the MSU 

designated MSU2 is available to this 
MCM. 

0:1 When AVI is a "1", the MSU 

designated MSU1 is available to this 
MCM. 

MEMORY REQUESTOR INHIBITS WORD 

The Memory Requestor Inhibits word loads 
the requestor inhibit register with new data to 
indicate which requestors now have access to 
the MCM. This word follows the special re- 
quest signal and the memory requestor inhib- 
its load control word during memory control 
operations between the MCM and requestor. 
The format, bits and fields of the Memory Re- 
questor Inhibits word are described below: 
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Field 

PARITY 


Bits 

51:1 


Description 

The MCM examines the requestor 
inhibit word for odd parity. 




50:44 


Unused 



R17 7:1 When bit R17 is a "1", the 

requestor who is designated 
requestor 7 is inhibited from access 
to the MCM. 

R16 6:1 When bit R16 is a "1", the 

requestor who is designated 
requestor 6 is inhibited from access 
to the MCM. 

R15 5:1 When bit R15 is a "1", the 

requestor who is designated 
requestor 5 is inhibited from access 
to the MCM. 

R14 4:1 When bit R14 is a "1", the 

requesto:- who is designated 
requestor 4 is inhibited from access 
to the MCM. 

R13 3:1 When bit R13 is a "1", the 

requestor who is designated 
requestor 3 is inhibited from access 
to the MCM. 



R12 2:1 When bit R12 is a "1", the 

requestor who is designated 
requestor 2 is inhibited from access 
to the MCM. 

RH 1:1 When bit Rll is a "1", the 

requestor who is designated 
requestor 1 is inhibited from access 
to the MCM. 

R10 0:1 When bit RIO is a "1", the 

requestor who is designated 
requestor is inhibited from access 

to the MCM. 



SIGNAL INTERFACE BETWEEN REQUESTOR, 
MCM, AND MSU 

The control and information flow between 
the requestor, MCM, and MSU is described in 
the following paragraphs and shown in figure 
V-l-10. 



SIGNAL INTERFACE BETWEEN MCM AND 
REQUESTOR 

1. Data and, Parity. Data and parity are 
transferred between a requestor and an MCM 
via a unique set of 52-bidirectional data lines. 
These lines are also used for the transmission 
of the control word. 

2. Special-Request Signal (RQSN). A special- 
request signal (RQSN) is used by a CPM to 
gain access to a memory control module (re- 
gardless of the state of the requestor-inhibits 
register). The RQSN signal goes "true" in coin- 
cidence with the request signal (REQ) when- 
ever a Memory Address Limit Load or Reques- 
tor Inhibits Load operation is performed. 

3. Request Signal (REQN). A request signal 
(REQN) is sent by a requestor to select a spe- 
cific MCM. REQ goes "true" one clock period 
prior to the request strobe (RSTB) and re- 
mains "true" until the receipt of an acknowl- 
edge signal (ACK) from the MCM. 

4. Data-Strobe Signal (DSTB). A data-strobe 
signal (DSTB) is sent to inform the MCM that 
data is to be transmitted over the data lines. 
The signal is used only in the N-length 
overwrite and the N-word protected write op- 
erations. The data strobe precedes the data 
word by one clock and its width indicates the 
number of data words following it. 

5. Request-Strobe Signal (RSTB). A request- 
strobe signal (RSTB) is sent to inform the 
MCM that a control word is being transferred 
over the data lines. It is "true" initially one 
clock period following the start of the reauest 
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Figure V-1-10. Requestor-MCU-MSU Interface 



signal (REQ). The control word is transmitted 
in coincidence with the request strobe. 

a. Single-word protected write and single- 
word overwrite: The request strobe 
(RSTB) will cycle "true" and "false" 
during successive clock periods. During 
the "false" period, the data word to be 
stored is placed on the data lines. 
All other operations: The request strobe 
(RSTB) is "true" one clock period following the 
request signal (REQN) and remains "true" un- 
til the acknowledge signal (ACK) is received. 

6. Data-Available Signal (DAV). A data- 
available signal (DAV) is transmitted to the 
requestor to indicate that data is available 
and will be transmitted in the following clock 
period. 

7. Acknowledge Signal (ACK). An acknowl- 
edge signal (ACK) of one clock period duration 
is sent to the requestor to signify that the 
MCM has accepted the control word and is 
processing the request. 



8. Send-Data Signal (SND). A send-data sig- 
nal (SND) is sent to the requestor during an 
N-length overwrite and may be sent during an 
N-word protected write. The send-data signal 
indicates the number of data words that must 
be transmitted to the MCM. The number of 
words to be transmitted is equal to the num- 
ber of clock periods the send-data signal is 
"true." 

NOTE 
The send data signal will not be 
transmitted if an attempt is made 
to write into a protected area dur- 
ing an N-word protected write. 
Also, the number of data words re- 
quested by the MCM must be 
transferred before a requestor 
ends his operation. 

9. Data-Present Signal (DAPB). Signal 
DAPB is sent to the requestor to indicate that 
a valid data word (or words) is being trans- 
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mitted from the MCM. The DAPB is trans- 
mitted in coincidence with the data word. A 
word is transmitted each clock period that the 
DAPB is "true." 

10. Requestor-Operation Complete Signal 
(RQOC). The MCM sends a one-clock-period re- 
questor-operation-complete signal (RQOC) to 
signify the end of the requestor's part of the 
memory operation. 

The following variations apply: 

a. Single or N-length fetches; single-word 
overwrite with flashback: The RQOC is 
sent coincident with the final clock peri- 
od of the data-present signal (DAPB). 

b. Single-word overwrite; N-length overwr- 
ite or N-word protected write: The 
RQOC signal is sent following the check 
of parity on the final data word re- 
ceived by the MCM. 

c. Single or N-word protected write: The 
RQOC signal is sent with or following 
FALS signal if word(s) are protected in 
N-word protected write. 

d. Single word overwrite without flash- 
back: An RQOC is generated following 
the check of parity on the data word re- 
ceived by the MCM. 

11. Address Upper Limit. The Address Up- 
per Limit is the most significant six bits of the 
highest 20-bit memory access available to this 
MCM (the least significant 14 bits are assumed 
to be "l's"). 

12. Address Lower Limit. The Address Low- 
er Limit is the most significant six bits of the 
lowest 20-bit memory address available to this 
MCM! (the least significant 14 bits are assumed 
to be 0's). 

13. Requestor-Enable Signal. The MCM 
sends to the requestor an enable signal which 
is used to enable or disable communications 
between the MCM and the requestor. 

1. Whenever the MCM is power cycling up 
or down. 

2. Whenever the appropriate requestor in- 
hibit FF is set. 

14. MCM-Enable Signal. The requestor 
sends to the MCM an enable signal which is 
used to enable or disable communications be- 
tween the requestor and the MCM. This signal 
is a steady-state signal which disables commu- 
nications whenever the requestor is power cy- 
cling up or down. 

15. Failure Interrupt 1 Signal (FAL1). The 
MCM transmits a one-clock period FAIL 1 in- 



terrupt signal to the requestor if any of the 
following errors occur: 

1. Control word parity 

2. Illegal operation code 

3. Wrong MCM 

4. Data strobe error 

5. 2-bit error 

6. Internal error 

The MCM Fail Register will then be loaded 
with information to facilitate error analysis. 

16. Failure Interrupt 2 Signal (FAL2). The 
MCM transmits a one-clock period FAIL 2 in- 
terrupt to the requestor if a 1-bit error occurs. 
The MCM Fail Register will then be loaded 
with information to facilitate error analysis. 

17. Software Interrupt (FALS). A one-clock- 
period software error interrupt is transmitted 
to the requestor during a single-word or N- 
word protected write operation if the memory 
word being examined contains a "1" in bit 48. 

SIGNAL INTERFACE BETWEEN MCM AND MSU 

1. Data Input Lines (60). Data, error correc- 
tion code, and overall parity are transferred 
from MCM to MSU via a set of 60 data lines. 

2. Data Output Lines (60). Data, error cor- 
rection code, and overall parity are trans- 
ferred from MSU to MCM via a set of 60 data 
lines. 

3. Read Available Signal. The read available 
signal is sent to inform the MCM that read 
data is available. 

4. MSU Parity Error Signal. The MSU 
parity error signal is sent by the MSU to indi- 
cate that an address and control parity error 
occurred. 

5. MSU Available Signal. The MSU available 
signal is sent to the MCM to indicate that 
MSU power is on. 

6. Address Lines (16). The MCM sends to the 
MSU a 16-bit address which specifies the mem- 
ory location to be accessed. 

7. Address And Control Parity. The MCM 
sends to the MSU an odd parity bit for the 16- 
address signals, the read/write mode signal, 
and the read/modify/write signal. 

8. Read/Write Mode Signal. The read/write 
mode signal, when true, indicates that a write 
operation is to be performed by the MSU. 

9. Read/Modify/Write Signal. The read/ 
modify/write signal, when true, in conjunction 
with the read/write mode signal indicates that 
a read/modify/write (split cycle) operation is to 
be performed by the MSU. 
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10. Initiate Memory Cycle Signal. The initi- 
ate memory cycle signal is sent by the MCM to 
start the MSU operation and to strobe the ad- 
dress and control information into the MSU. 

11. Write Strobe Signal. The write strobe 
signal is used to strobe write data from the 
MCM into the write register of the MSU. 

12. Data Select Write Signal. The data select 
write signal is sent by the MCM during a read/ 
modify/write operation. This signal is used to 
specify that data in memory is either restored 
from the read register or overwritten with 
new information from the write register. 

13. Remote Power On/Off Signal. The re- 
mote power an/off signal allows power se- 
quencing of the MSU to be controlled by the 
MCM. 

14. Control Clear Signal. The control clear 
signal is sent by the MCM to clear various con- 
trol flip-flops and registers in the MSU. 

DEFINITION OF MCM OPERATIONS 

The various MCM operations are briefly de- 
scribed in the following paragraphs. 

1. Data-Word Fetch (Single or Multiple 
Word). This operation is a standard fetch of 
data. If a multiple word fetch is initiated, the 
data words are transferred to the requestor at 
the clock rate, i.e., 123 nanoseconds, and 
within the limits discussed previously. 

2. Fail-Word Fetch. This operation is a fetch 
of the fail register within the MCM. The fail 
register is cleared as a result of this operation. 

3. Single-Word Overwrite with Flashback. 
This operation is a standard write/read 
operation. The data from the requestor is writ- 
ten into the addressed location. The original 
data read out of the address location is trans- 
ferred back - or flashed back - to the reques- 
tor. . 

4. Single-Word Protected Write (with/with- 
out flashback). This operation is a conditional 
write of data into memory. The data word 
transferred by the requestor is written into 
memory only if the address is not protected 
(i.e., bit 48 of the original word is "0"). The re- 
questor may indicate whether he requires 
flashback; however, the MCM will uncondition- 
ally flash back data to the requestor. The 
MCM will send a Fail S signal to the requestor 
if the address was protected. 

5. Overwrite (Single or Multiple Word. This 
operation is a standard write of data into 
memory. If the operation is an overwrite, the 
rate of data transfer to the MCM will be con- 
trolled by the MCM. 

6. Multiple-Word Protected Write (1 > N > 4). 
This operation is a conditional write of data 
into memory. The data is written into memory 
as long as none of the addresses are protected 



(i.e., bit 48 = for each address). The reques- 
tor will transmit the data only upon request of 
the MCM. The MCM will transmit a Fail S sig- 
nal to the requestor if any of the addresses 
were protected, and it will unconditionally 
flashback data to the requestor. 

7. Load Requestor Inhibit Register. This op- 
eration is similar to a single-word overwrite 
with the exception that the data word is trans- 
ferred to the requestor inhibit register instead 
of to the MSU. The state of the requestor in- 
hibit register determines which requestors 
may communicate with the MCM. 

8. Load Memory Limit. This operation is 
similar to a single-word overwrite with the ex- 
ception that the limits field within the data 
word is transferred to the memory limit regis- 
ter instead of to the MSU. The memory limits 
consist of the lower and upper MCM memory 
addresses and the MSU's available for usage 
by the MCM. 

MCM LOGIC FUNCTIONS 

The basic logic functions of the MCM are: 
priority resolution, data transfer and control, 
and error protection. (See the block diagram in 
figure V-l-11.) 

PRIORITY-RESOLUTION LOGIC 

Priority-resolution logic controls communica- 
tions between each requestor and the MCM. 
Lower numbered requestors are given the 
highest-priority access into memory. Only 
those requestors selected by the state of the 
requestor-inhibit register are allowed to be 
serviced by the MCM. The exception to this 
rule is that through the use of the special re- 
quest signal, CPM's are able to override the 
state of the requestor inhibit register. A re- 
questor is not serviced if the requestor's inter- 
face has failed so that other requestors are 
not locked out. The highest-priority requestor 
is prevented from obtaining consecutive serv- 
ice if a lower priority requestor is waiting to 
be serviced. 

DATA-TRANSFER-AND CONTROL LOGIC 

The data-transfer and control logic provides 
the sequential control signals required to 
route the data through the four main data 
registers (input, output, control word, and 
memory buffer registers). A brief description 
of these registers is provided below: 

a. Input Register. A 52-bit register used as a 
temporary buffer register for control words 
and data words received from memory. 

b. Memory Buffer Register. A 60-bit register 
used as a temporary buffer register for data 
words transferred to or from MSU's. The 
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memory buffer register. During a fetch the 
fail-register operation, the fail register infor- 
mation, except bit FR.51, is transferred to the 
MBR before being placed in the output regis- 
ter. 

c. Control Word Register. A 52-bit register 
used to contain the control word transmitted 
by the requestor. 

d. Output Register. A 52-bit register used to 
buffer data words that are being transmitted 
to a requestor during a fetch operation. The 
output register also contains the bit-correction 
logic required to correct one-bit errors detect- 
ed by the error-correction logic. 

ERROR-DETECTION LOGIC 

The error-detection logic detects errors in re- 
questor and MSU data and control interface; 
detects multiple bit errors; corrects on-bit er- 
rors that occur in the MSU during a fetch op- 
eration; and detects an internal error if a fail- 
ure occurs in the check/generator logic. 

MSU OPERATIONAL MODES 

There are three operational modes provided 
by the MSU: read/restore, clear/write, and 
read/modify/write. A brief description of these 
operational modes is given below: 

1. Read/Restore. The MSU reads out data 
from the memory address defined by the MCM 
and places the data on the bus to the MCM. 
The MSU rewrites the information back into 
the core memory at the defined address. 

The following MCM operations use this MSU 
operation: 

a. Single-word fetch 
lb. N-length word fetch 

2. Clear/Write. The MSU reads out data 
from the memory location addressed by the 
MCM and places the data on the bus to the 
MCM. The MSU accepts information from the 
MCM and stores it into the addressed location. 
The following MCM operations use this MSU 
operation: 

a. Single-word overwrite with or without 
flashback. 



b. N-length overwrite. 

c. Single-word protected write. 

3. Read/Modify/Write. The MSU reads out 
data from the memory location addressed by 
the MCM and places the information on the 
bus to the MCM. The MSU on command from 
the MCM, stores into the same address either 
the original information read from memory or 
information transmitted from the MCM. The 
N-word protected write uses this MSU 
operation. 

MASTER CLOCK AND SYSTEM DISTRIBUTION 

The master clock for a B 7700 System is 
housed in the MCM cabinet designated MCM- 
0. Although all MCM's are so configured that 
they could house the master clock kit, only one 
master clock is used per system. 

The master clock consists of three circuit 
cards: the crystal-controlled master clock, 
2MHz countdown, and crystal-controlled 5MHz 
clock. The crystal-controlled master clock pro- 
vides three outputs consisting of the following: 
a 16MHz signal which is supplied to the CPM's 
as the clock signal for the program control 
unit, storage unit, and execution unit; an 
8MHz phase-1 signal which is supplied to the 
CPM's (communications unit only), IOM's, and 
MDU's as the basic clock signal for internal 
and interface timing; and an 8MHz phase-2 
signal which is supplied to all MCM's as the 
basic clock signal for internal and interface 
timing. The 2MHz countdown circuit card 
steps down the 8MHz phase-1 signal to provide 
a 2MHz clock signal for the disk file optimizer 
(DFO). (The DFO does not contain an internal 
clock generator.) The 5MHz crystal-controlled 
oscillator provides the clock signal for the data 
communications processor. 

The master clock system obtains its dc input 
power from special power supplies that are iso- 
lated from the normal power supplies in each 
module. Therefore, if the MCM containing the 
master clock is shut down, the master clock 
will continue to drive the other MCM's and 
system modules. 
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CHAPTER VI 
CONTROLS AND INDICATORS 



SECTION 1 



OPERATING CONTROLS 



INTRODUCTION 

This section describes the controls and indi- 
cators used in the operation of the B 7700 sys- 
tem. These controls and indicators are located 
on the operators control console and on the 
cold start/halt load selection cards. The 
operators control console (figure VI-1-1) con- 
sists of a console control panel and one or 
more supervisory console devices, each of 
which contains an input keyboard and a video 
output screen. The cold start/halt load selec- 
tion cards are mounted in the backplane of 
each CPM and IOM. 



CONSOLE CONTROL PANEL 

The console control panel (figure VI-1-2) in- 
cludes the following switches and indicators. 

SYSTEM A/SYSTEM B - This switch selects 
the portion of the system which will be af- 
fected by the remaining switches on the con- 
sole control panel. Each main frame module 
(CPM's, IOM's, and MCM's) includes a SYS- 
TEM A/SYSTEM B switch which determines 
which portion of the system that module be- 
longs to. Only those mainframe modules be- 
longing to the selected portion of the system 



SUPERVISORY 

CONTROL 

DEVICES 




Figure VI-1-1. Operators Control Console 
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Figure VI-1-2. Console Control Panel 



are affected by operation of the console con- 
trol panel switches. 

The SYSTEM A/SYSTEM B switch is lo- 
cated on a switch card (the COLD START/ 
HALT LOAD selection card) mounted on the 
backplane of a CPM or IOM. The SYSTEM A/ 
SYSTEM B switch is mounted on the cabinet 
frame at the right side of the panel of an 
MCM. 

DISK LOAD/CARD LOAD - This switch se- 
lects the load operation that will be performed 
when the system is started. 

When set to CARD LOAD, indicate that a 
card load has been selected. 

When set to DISK LOAD, indicates that a 
disk load has been selected. 

Note that this switch selects the mode of op- 
eration, but does not cause the operation. 

HALT - Halts the system in an orderly fash- 
ion. Sets CPM's to single instruct mode, which 
causes a halt at the end of the current pro- 
gram operator, and sets IOM's to inhibit state, 
which inhibits the initiation of further I/O op- 
erations. I/O operations in progress will be 
completed. 

LOAD - Clears all hard registers and flip- 
flops to the reset state. Sets IOM's to inhibit 
state, sets IOM Home Address registers to the 
memory segment indicated by the switch set- 
tings, and clears the peripheral controllers. 



Sets the MCM requestor inhibit, address lim- 
its, and availability registers to the switch set- 
tings. Sets the CPM's yp control state, control 
mode 3 in a forced PAUS instruction. Upon re- 
ceipt of an external interrupt, the CPM will 
execute code starting at word 8 of the memory 
segment set into the switch card. 

ENABLE - Causes the IOM selected as the 
load IOM to initiate a read operation from ei- 
ther card or disk, depending on the setting of 
the COLD START/HALT LOAD switch. 

If a card load was selected, cards will be 
read from the card reader specified by the 
switch settings until a validity check occurs. 

If a disk load was selected, 8192 words will 
be read from address zero of the disk unit 
specified by the switch settings. 

At the completion of the read operation, the 
CPM specified by the switch settings will be 
interrupted. 



SUPERVISORY CONSOLE 

The supervisory console (figure VI-1-3) con- 
tains an input keyboard and a video output 
screen. 
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Figure VI-3. Supervisory Console 



KEYBOARD CONTROL KEYS 

The following is a list of the keyboard con- 
trol keys and their functions (figure VI-1-4): 



XMT mode key and 
indicator 



RCV mode key and 
indicator 



The transmit (XMT) mode indicator is illuminated when the transmit (XMT) key is 
depressed. The indicator is extinguished when a transmission from the terminal has 
been positively acknowledged by the receiving station or the terminal is changed to 
the local mode by the operator. 

The receive (RCV) mode indicator, which indicates that the terminal is ready to 
receive data, is illuminated when the receive (RCV) key is depressed. The indicator is 
also illuminated when a transmission from the terminal has been successfully 
completed. The RCV indicator is extinguished when the terminal is switched to local 
mode, or transmit mode. 
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Figure VI-1-4. Keyboard Format 
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LOCAL mode key and 
indicator 



ERROR indicator 



ENQ indicator 



FORMS push button and 
indicator 



LTAI indicator 



ETX (X) 



Key 
X(Line feed) 

T (Reverse Line feed) 



(Backspace) 



(Forward space) 



HOME 

CLEAR 
RPT 



(Carriage Return) 
TAB 



The local mode indicator is illuminated when the LOCAL key is depressed or by the 
use of the keyboard when the terminal is in the receive mode with no data being 
received into the terminal. The indicator is extinguished when the terminal is switched 
to the receive mode or transmit mode. 

The error indicator is illuminated when a parity error is detected by the terminal in 
the data being received, or when the buffer overflows because the received message 
contains more characters than the character capacity of the display circuits. The error 
indicator is extinguished by the successful retransmission to the terminal, the receipt 
of a new message. 

The enquiry (ENQ) indicator is illuminated when the terminal detects the central 
processor (CP) attempting to transmit a message to the terminal while the terminal is 
not in the receive mode. The indicator is extinguished by the operator placing the 
terminal in the receive or local mode. Also, the audible alarm momentarily sounds 
when the ENQ indicator is lit. 

The FORMS indicator is illuminated whenever the terminal is operating in the forms 
status. The terminal operates in the forms status when the FORMS push button is 
depressed by the operator and delimiters are present. The FORMS indicator is 
extinguished either by the receipt of a CP message or by depressing the FORMS push 
button. 

The line terminal activity indicator (LTAI) is illuminated whenever data is transmitted 
from the CP to the terminal on the line. When the terminal responds to the CP, the 
LTAI indicator is extinguished. In normal operation, the LTAI will blink due to the 
data line activity. An LTAI which is not illuminated indicates that the CP is not 
transmitting on that line. An LTAI which remains illuminated indicates that the 
terminal is not responding. 

The ETX (end-of-text) key causes the ETX symbol (X) to be stored in memory and 
displayed at the cursor location. When this operation is completed, the cursor is then 
automatically moved to the home position. 

Line feed is used to move the cursor one line down. When the cursor is in the bottom 
line, depressing the line feed key causes the cursor to reappear in the top line. This 
function is disabled when the terminal is in the forms status. 

Reverse Line feed is used to move the cursor one line up. When the cursor is in the 
top line, depressing the reverse line feed key causes the cursor to reappear in the 
bottom line. This function is disabled when the terminal is in the forms status. 

Backspace is used to move the cursor one character to the left. When the cursor is in 
the first character position (left edge) of the display, depressing the backspace key 
causes the cursor to reappear in the last character position (right edge) of the next 
higher line. When the cursor is in the "home" position (top line, left edge), depressing 
the backspace key causes the cursor to reappear in the last character position (bottom 
line, right edge). In forms status, backspace is enabled only to the first character 
location in an unprotected data field. 

Forward space is used to move the cursor one character position to the right. If the 
cursor is at the right edge of a line, depressing the forward space key causes the 
cursor to reappear at the left edge, down shifted one line. If the cursor is located in 
the last character position of the bottom line, depressing the forward space key causes 
the cursor to reappear in the home position. In forms status, forward space causes the 
cursor to move from the last position of an unprotected field to the first position of 
the succeeding unprotected field. 

The HOME key is used to move the cursor to the upper left (home) position. In forms 
status, HOME causes the cursor to be moved to the first position of the first 
unprotected data field. The HOME key operates in unshifted mode only. 

Depressing the CLEAR key and the shift key will cause all data on the display to be 
erased except protected data while in the forms mode. 

Repeat (RPT), when depressed along with any alphanumeric key, return, insert, delete, 
line feed, reverse line feed, backspace, or forward space, causes the repetition of that 
character or function in successive display and memory locations. 

The carriage return key is used to move the cursor from its position in a line to the 
first position of the following line. The carriage return symbol (^7 ) is stored and 
displayed at the cursor position before the actual carriage return takes place. In 
forms status, the carriage return key is disabled. 

TAB is used to move the cursor forward to the next tab stop location. The tab stops 
are located at character positions 1, 9, 17, 25, 33, 41, 49, 57, 65, and 73 of each line. In 
the forms status, TAB causes the cursor to move forward to the first unprotected 
character position following the leading delimiter of the next unprotected character 
field. 
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us[> 

(Unrestricted Delimiter) 



RS < 

(Restricted Delimiter) 



LINE ERASE 



CHAR INS 
(Character Insert) 



CHAR DEL 
(Character Delete) 



Depressing the US > key and the shift key will cause an unrestricted delimiter 
symbol ( |> ) to be inserted into memory and displayed at the cursor location. This 
symbol has no significance until the terminal is placed in the forms mode. In the 
forms mode, the data on the screen between the US symbol ( |> ) and the RS symbol 
( <J ) is interpreted as unprotected data and the US [> key on the keyboard is 
disabled. 

Depressing the RS <] key and the shift key will cause a restricted delimiter symbol 
( <| ) to be inserted into memory and displayed at the cursor location. This symbol 
has no significance until the terminal is placed in the forms mode. In the forms mode 
the data on the screen between the RS symbol ( <j ) and the US symbol ( t> ) is 
interpreted as protected data and the RS < key on the keyboard is disabled. 
The LINE ERASE key when depressed, will erase all of the data on a line to the 
right of, and including the cursor position. In forms status, the LINE ERASE key is 
disabled. 

The character insert key when depressed, inserts a space at the cursor location, and, 
together with the key of the character to be inserted causes the added character to 
appear at the cursor location. The succeeding characters are moved one space to the 
right and downward from line to line. Surplus characters, if any, are shifted off the 
display at the end of the last line. 

The character delete key is used to remove a displayed character from the cursor 
location. When the CHAR DEL key is depressed, the succeeding characters are moved 
one space to the left and upward from line to line. 



DISK LOAD/CARD LOAD 

The COLD START/HALT LOAD Selection 
Card (figure VI-1-5) mounted in the backplanes 
of each CPM and IOM contain switches which 
are used to identify the CPM, MCM, IOM, card 
reader, and disk file electronics unit to be used 
when initializing the system. 

The COLD START/HALT LOAD Selection 
Card contains the following switches: 

Select (8) - Selects the load IOM. Must be 
ON for the load IOM, and OFF for all others 
in that portion of the system. 

A/B (7) - Determines which portion of the 
system (system A or system B) this module be- 
longs to. 

MEMORY NO. (1-6) - Indicates the 16K 
memory segment to b€i used for initialization 
(most significant six bits of the memory ad- 
dress). Should be set to 000000. 

CPM INTERRUPT NO. (14-16) - Indicates 



the channel number (binary) of the load CPM, 
i.e., the CPM which is to be interrupted fol- 
lowing the load operation. 

CARD READER CHANNEL NO. (9-13) - 
The number of the channel (internal to the 
load IOM) to which the load card reader is con- 
nected. 

DISK FILE CHANNEL NO. (17-21) - The 
number of the channel (internal to the load 
IOM) to which the desired disk file exchange is 
connected. 

EU UNIT DESIGNATE NO. (25-32) - The 
unit designate number of the desired electron- 
ics unit. The transfer from the EU will start 
at SU 0, zone 0, track 0, segment of the spec- 
ified EU. 

A CPM uses only the MEMORY NO. and A/ 
B switches. An IOM other than the load IOM 
uses the SELECT switch (must be OFF), the 
MEMORY NO., A/B, and CPM INTERRUPT 
NO. switches. The load IOM uses all switches. 
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Figure VI-1-5. Cold Start/Halt Load Selection Card 



SECTION 2 



CENTRAL PROCESSOR MODULE PANELS 



This section describes the functions and 
uses of the controls and indicators on the two 
panels of the central processor module (CPM). 
An overall view of the central processor mod- 
ule is shown in figure VI -2-1, and close-ups of 
the panels are shown in figures VI -2-2 and 
VI -2-3. 

DISPLAY ORGANIZATION 

The Central Processor Module has two adja- 
cent panels for display purposes. Each panel 
has fifteen rows of indicators, a row of 51 
toggle switches, and a section of maintenance 
switches. Legends are printed on the left-hand 
margin of each panel which indicate the gen- 
eral area a series of rows pertain to. Row 
numbers are printed on the right-hand mar- 
gin. 

Occasionally, a row of indicators will have 
two printed row numbers. When this occurs, 
the single row of indicators is used to display 
one of two sets of data as specified by a two 



position toggle switch which is to the left of 
the row markings. The descriptions of each set 
either have the format upper switch setting/ 
lower switch setting or are printed above and 
below the individual indicators. 

The indicators within each row are 
separated into groups of four by color for hex- 
adecimal grouping purposes as is the row of 51 
toggle switches. 

PANEL 2 INDICATORS (LEFT-HAND PANEL) 

EU DATA SECTION 

ROW 1 - ROW 21 DISPLAY SELECTION 

The first row of indicators is used to display 
the contents of either row 1 or row 21. The se- 
lection of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the first row of indicators and which is labeled 
EW-C. 
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PANEL 1 



PANEL 2 



Figure VI-2-1. Central Processor Module 
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Figure VI-2-2. Panel 2 (Left-Hand Panel) of CPM 
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Figure VI-2-3. Panel 1 (Right-Hand Panel) of CPM 



ROW 1 

EU WRITE REGISTER (EW51-0) - The pri- 
mary input to the Execution Unit (EU) for all 
data with the exception of operators. 

PAR (EW51) - The parity bit of the operand 
in the EU Write Register (EWR). 

TAG (EW50-48) - The tag bits of the operand 
in the EWR. 

ROW 21 

C REGISTER (C51-0) - The only output from 
the EU and the input to EU Local Storage. 
The following EU error checks occur in this 
register: 

1. Some residue generation. 

2. All residue checking. 

3. All continuity checking. 

4. Some parity generation and checking. 
PAR (C51) - The parity bit of the operand in 

the C Register. 

TAG (C50-48) - The Tag bits of the operand 
in the C Register. 



ROW 2 - ROW 22 DISPLAY SELECTION 

The second row of indicators is used to dis- 
play the contents of either row 2 or row 22. 
The selection of the row to be displayed is 
made through use of a toggle switch which is 
located on the right hand side of the panel ad- 
jacent to the second row of indicators and 
which is labeled E-D. 

ROW 2 

E REGISTER 

CHECK 

XV - EXV is the "E" Register exponent valid 
bit which is functional in arithmetic mode 
only. 

DV - EDV is the "E" Register data valid bit 
which indicates validity for either the entire 
word when in word mode or for the mantissa 
when in arithmetic mode. 

R1,0 - ER1,0 is the "E" Register residue. 

BITS 47-0 - E47-0 is the "E" Register which 
is one of the inputs to the adder and T bus. 
This register contains the "A" operand when 
the processor is in Single Instruct. 

ROW 22 

D REGISTER 

CHECK 

XV - DXV is not used. 



DV - DDV is the "D" Register data valid bit. 

R1,0 - DR1,0 is the "D" Register residue. 

BITS 47-0 - D47-0 is the "D" Register which 
is the input register to the EU Barrel. 

ROW 3 - ROW 23 DISPLAY SELECTION 

The third row of indicators is used to display 
the contents of either row 3 or row 23. The se- 
lection of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the third row of indicator and which is labeled 
F-G. 

ROW 3 

F REGISTER 

CHECK 

XV - FXV is the "F" Register exponent valid 
bit which is functional in arithmetic mode 
only. 

DV - FDV is the "F" Register data valid bit 
which indicates validity for either the entire 
word when in word mode or for the mantissa 
when in arithmetic mode. 

R1,0 - FR1.0 is the "F" Register residue. 

Bits 47-0 - F47-0 is the "F" Register which 
is one of the inputs to the adder and also feeds 
the S bus. This register contains the "B" oper- 
and when the processor is in Single Instruct. 

ROW 23 

G REGISTER 

CHECK 

XV - GXV is not used. 

DV - GDV is the "G" Register data valid bit. 

R1,0 - GR1.0 is the "G" Register residue. 

Bits 47-0 - G47-0 is the "G" Register which 
is the third input to the adder. 

ROW 4 

A CONTROL REGISTER - Contains control 
bits for the "A" operand. 

ME - AME indicates an "A" word memory er- 
ror. The memory control word is returned 
rather than the expected data. 

Bits 50-45 - A50-45 correspond to bits 50-45 in 
an operand. 



6-12 



NT - ANT indicates that "A" is an integer and 
is true if bits 45-39 in the "A" operand are 
zero. 

NC - ANC indicates tha.t the "A" operand is in 
the "C" Register. The contents of "C" thus de- 
termine the setting of ANC. 

NV - ANV indicates that the "A" Control Reg- 
ister has not yet been completely updated. 

EU WRITE REGISTER EXTRAS (EW) 

CHECK 

PV - EWPV is EWR parity valid. 

DV - EWDV is EWR data valid. 

ER - EWER is EWR word parity error. A 
memory control word has been substituted for 
the expected data. 

R1,0 - EWR1.0 is the EWR residue. 



KL WRITE RESIDUE 

K1,0 - "K" Register write residue. 

L1,0 - "L" Register write residue. 
C REGISTER EXTRAS 

CHECK 

PV - CPV is the "C" Register parity valid bit. 

DV - CDV is the "C" Register data valid bit. 

ER - CER is the "C" Register memory error 
bit. A 

ER - CER is the "C" Register memory error 
bit. A memory control word has been substi- 
tuted for the expected data. 

R1,0 - CR1,0 is the "C" Register residue. 

EXPONENT 

XV - CXV is the "C" Register exponent valid 
bit. 

XR1,0 - CXR1,0 is the "C" Register exponent 
residue. 

OVERFLOW (M44-39) - CM44-39 are the "C" 
Register mantissa overflow bits which are an 
extension for the arithmetics. 

E REGISTER EXTRAS 

EXPONENT (XR1.0) - EXR1.0 is the "E" Reg- 
ister exponent residue. 



OVERFLOW (M41-39) - EM41-39 is the "E" 
Register mantissa overflow. 

F REGISTER EXTRAS 

EXPONENT (XF1.0) - FXF1,0 is the "F" Reg- 
ister exponent residue. 

OVERFLOW (041-39) - F041-39 is the "F" Reg- 
ister mantissa overflow. 



R REGISTER 

R1,0 - RR1,0 is the "R" Register residue. 

Bits 05-0, R05-0 is the "R" Register which is 
used as both a repeat counter and general ac- 
cumulator. 



ROW 5 - ROW 25 DISPLAY SELECTION 

The fifth row of indicators is used to display 
the contents of either row 5 or row 25. The se- 
lection of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the fifth row of indicators and which is labeled 
B, K, L, AP, BP - W, SH, AL, RP, WP. 



ROW 5 

B CONTROL REGISTER - Contains control 
bits for the "B" operand. 

ME - BME indicates a "B" word memory er- 
ror. The memory control word is returned 
rather than the expected data. 

Bits 50-45 - B50-45 corresponds to bits 50-45 in 
an operand. 

NT - BNT indicates that "B" is an integer and 
is true if bits 45-39 in the "B" operand are 
zero. 

NC - BNC indicates that the "B" operand is in 
the "C" Register. The contents of "C" then de- 
termine the setting of BNT. 

K REGISTER 
R1,0 - KR1.0 is the "K" Register residue. 
Bits 7-0 - K7-0 is the "K" Register which is 
the output of the "K" Queue. The "K" Queue 
contains the variant for normal operators and 
the starting bit number within a word for sin- 
gle word string operations. 
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L REGISTER 

R1,0 - LR1.0 is the "L" Register residue. 

Bits 7-0 - L7-0 is the "L" Register which is 
the output of the "L" Queue. The "L" Queue 
contains the variant for normal operators and 
the length for string ops on single word 
operations. 

A POINTER (AP) - Used with "A" Local 
storage and will point at the next character to 
be used in the "A" operand local storage area. 

QS - APQS is the "A" pointer output select. 

R1,0 - APR1,0 is the "A" pointer residue. 

Bits 6-0 - AP6-0 is the "A" operand shift and 
allow data to allow the pointed data to be ob- 
tained. 

B POINTER (BP) - Used with "B" local stor- 
age and will point at the next character to be 
used in the "B" operand local storage area. 

QS - BPQS is the "B" pointer output select. 

R1,0 - BPR1.0 is the "B" pointer residue. 

Bits 6-0 - BP06-0 is the "B" operand shift and 
allow data pointed to be obtained. 

ROW 25 

W CONTROL REGISTER - General use reg- 
ister. 

ME - WME indicates a "W" word memory er- 
ror. The memory control word is returned 
rather than the expected data. 

Bits 50-45 - W50-45 corresponds to bits 50-45 in 
an operand. 

NT - WNT indicates that "W" is an integer 
and is true if bits 45-39 in the "W" operand are 
zero. 

NC - WNC indicates that the "W" operand is 
in the "C" Register. The contents of "C" then 
determine the setting of WNT. 

SHIFT REGISTER (SH) - Shift factors for 
the EU Barrel in octades and bits. 

R1,0 - SHR1,0 is the Shift Register residue. 

V - SHV is shift valid. 

Bits 5-0 - SH5-0 is the Shift Register. 

ALLOW REGISTER (AL) - Allows "n" bits 
out of the EU Barrel. 



R1,0 - ALR1,0 is the Allow Register residue. 

V - ALV is Allow Register valid. 

LE - ALLE is allow left. 

Bits 5-0 - AL05-0 is the Allow Register. 

R POINTER (RP) - Used with "R" Local 
storage which holds the local destination infor- 
mation for string ops and is used for miscella- 
neous arithmetic partial results. 

QS RPQS is the "R" pointer output select. 

R1,0 - RPR1.0 is the "R" pointer residue. 

Bits 6-0 - RP06-0 is the "R" storage shift and 
allow data to allow the indicated character to 
be obtained. 

W POINTER (WP) - Used with "W" local 
storage which holds the local source informa- 
tion for string ops and is used for miscellane- 
ous arithmetic functions. 

QS - WPQS is the "W" pointer output select. 

R1,0 - WPR1.0 is the "W" pointer residue. 

Bits 6-0 - WP06-0 is the "W" storage shift and 
allow data to allow the indicated character to 
be obtained. 

EU CONTROL SECTION 

ROW 6 - ROW 26 DISPLAY SELECTION 

The sixth row of indicators is used to display 
the contents of either row 6 or row 26. The se- 
lection of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the sixth row of indicators and which is la- 
beled ARITH, WORD-CW, STRING. 

ROW 6 
ARITHMETIC FAMILY 

OPERATOR (AQ) 

Bits 5-0 - AQ5-0 is the Arithmetic Family Op- 
erator Register which contains the internal 
micro-op from either the EU Operator Queue, 
or if that is empty, directly from the OW Reg- 
ister. The contents of the Operator Register 
will cause the generation of certain commands 
or routines to be done to complete a required 
task. 
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A - AQA is the allow bit for the Arithmetic 
Family. The Operator Registers of all families 
are loaded simultaneously, the allow bit indi- 
cates when its associated operator register is 
active. 

TIME (AT3-0) - The Arithmetic Family oper- 
ator Timer. 



COMMAND (ARC) 

AQA1 - Duplicate of AQA for loading pur- 
poses. 

Bits 6-0 - ARC6-0 is the Arithmetic Family 
Command Register which contains the code of 
a command to perform a simple function (e.g., 
load a register). 

RESIDUE CONTROLS 

ABC2-0 - A type of command register for the 

Adder and Barrel for residue correction. 

BOC3-0 - Barrel Residue correction. 
WORD FAMILY 

OPERATOR (WQ) 

P5-0 - WQP5-0 is the Word Family Operator 
Register which contains the internal micro-op 
from either the EU Operator Queue, or if that 
is empty, directly from the OW Register. The 
contents of the Operator Register will cause 
the generation of a certain command or rou- 
tine. 

A1,0 - WQA1.0 is the allow bit for the Word 
Family. The Operator Registers of all families 
are loaded simultaneously. The allow bit indi- 
cates when its associated operator register is 
active. 

TIME (WT2-0) - The Word Family operator 
Timer. 

COMMAND (WC6-0) 

The Word Family Command Register which 
contains the code of a command. STORE 
Bits 5-0 - ST5-0 is the Store Command Regis- 
ter. It contains source and destination codes to 
enable data and address transfers outside of 
the EU. 

STORE 

Bits 5-0 - ST5-0 is the Store Command Regis- 
ter. It contains source and destination codes to 
enable data and address transfers outside of 
the EU. 
ZER - The "R" Register is zero. 



ROW 26 

CONTROL WORD FAMILY 

OPERATOR (COP) 

Bits 5-0 - COP5-0 is the Control Word Family 
Operator Register which contains the internal 
micro-op from either the EU Operator Queue, 
or if that is empty, directly from the OW Reg- 
ister. The contents of the Operator Register 
will cause the generation of a certain com- 
mand or routine. 

A - COPA is the Allow bit for the Control 
Word Family. The Operator Registers of all 
families are loaded simultaneously. The allow 
bit indicates when its associated operator reg- 
ister is active. 

TIME (OT3-0) - The Control Word Family op- 
erator Timer. 

COMMAND (CWC7-0) 

The Control Word Family Command Regis- 
ter which contains the code of a command. 

RESIDUE CONTROLS 

EWF2-0 - E, EWR, or F residue combined with 
Barrel residue. A code for the Specific type of 
combination. 

BLUE2-0 Barrel or Logic Unit Residue Correc- 
tion. 

STRING FAMILY 

OPERATOR (SQ) 

P5-0 - SQP5-0 is the String Family Operator 
Register which contains the internal micro-op 
from either the EU operator Queue, or if that 
is empty, directly from the OW Register. The 
contents of the Operator Register will cause 
the generation of commands or routines. 

A1,0 - SQA1,0 are the Allow bits for the String 
Family. The Operator Registers of all families 
are loaded simultaneously. The allow bit indi- 
cates when its associated operator is active. 

TIME (SQT2-0) - The string Family operator 
timer. 

COMMAND (SCM6-0) 

The String Family Command Register which 
contains the code of a command. 

T BACK-UP 

TBM - TBM5-0 is the T Back Up which is a 

coded source for additional data for the T 

Buss. 

TXN - T Back-up Register is not valid for an 
exponent. 
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ROW 7 

COMMON CONTROLS 

OPERATOR 

AFL - "A" full (at the start of the current EU 
operator). 

BFL - "B" full (at the start of the current EU 
operator). 

QEN - Last EU operator of any sequence sent 
by the PCU. 

QRP - Send report back to the PCU on the last 
command of the current operation (when the 
report bit is set). 

RM1-0 - Remember the current operator 
family and indicates which family is doing the 
operation. 

RMR - Remember return to the Control Word 
Family. This is used to return when a micro- 
op calls a micro-op of a different family. 

RMW - Remember return to the Word Family. 
This is used to return when a micro-op of a 
different family. 

RDB - Do a REDB (read "B") operator at the 
completion of the current operator. 

LOK - Lock K and L. 

ROUTINE 

CMV - Command variant to remember extra 

operand. 

RNP - Routine end of program operator (fol- 
lows QEN). 

RRP - Routine send report (follows QRP) 

RNE - Routine end of EU operator. This indi- 
cates the final routine of a micro-op. 

ROL - Routine operator load which indicates 
that the EU has generated a micro-op. The op- 
erator registers are loaded as a result of the 
command register contents. 

RAP - Routine advance of the PIR Queue read 
pointer. 

ENDR - End of routine. 

SGS - Single routine STOP which reflects the 
status of the Single Routine Stop button. 



STORE 

SNP - Store Level end of program operator. 
The result is in the C Register. This flip-flop is 
set after RNP is set. 

SNE - Store Level, end of EU operation. 

SAP - Store Level, advance. PIR Queue read 
pointer (from setting of RAP). 

ALLOCATION 

ABA - The current A/B allocation in EU local 

storage. 

AB1 - The initial A/B allocation in EU local 
storage. 

OCA - The current read allocation for the first 
group of EU local storage. 

ONA - The initial read allocation for the first 
group of EU local storage. 

1CA - The current read allocation for the sec- 
ond group of EU local storage. 

1NA - The initial read allocation for the sec- 
ond group of EU local storage. 

T AND S VALID 

TV - The T Buss was valid during the previous 

time. 



T1V - T initial valid. The T Buss will be valid 
at the end of the program operator. 

SV - The S Buss was valid during the previous 
time. 

S1V - S initial valid. The S Buss will be valid 
at the end of the program operator. 

PIR Q READ (PQR2-0) - The PIR Queue read 
pointer. The PIR Queue associates a program 
operator PIR address with a micro operator 
for interrupt purposes. 

STACK COUNT 

NSC - NSC2-0 is the New Stack Count and is 
used to count the pushes or pops done by a 
program operator. The NSC is added to STC to 
arrive at a new stack arrangement at the com- 
pletion of the program operator. 

STC - STC4-0 is the Stack Count which is used 
to re-establish the stack after an interrupt. 
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STATE FLIP-FLOPS 

CURRENT 

EFF - Equality flip-flop. 

EXT - Mantissa sign of the "A" operand. 

OFF - Overflow. 

TFF - True/false flip-flop. 

FLT - Float mode-used in edit operations. 

TFO - True/false flip-flop occupied (valid). 

INITIAL 

PST - Processor state-normal mode. 

DSF - Different segment-DSF:l=Dl relative, 
DSF:0=D0 relative. 

TF1 - True/false initial, the initial setting of 
TFF. 

FT1 - Float mode initial. 

TON - True/false occupied initial. 
ROW 8 

ROUTINE ALGORITHM FLIP-FLOPS 

TIME SHARED (VR) - VR5-0 contain the EU 

routine variants. 

DET - Descriptor size transfer. 

WORD FAM (WV) - WV2-0 contain the Word 
Family variants. 

EU OPERATOR ALGORITHM FLIP-FLOPS 

TIME SHARED (EQ) - EQ7-0 contain the EU 

program operator variants. 

COMMON 

SLO - The store level for the last operator 
from the EU Operator Queue. 

RRR - Remember to return at the end of a 
routine rather than exiting. This is used when 
one routine has called another routine. 

FMC - Family "C" operator (first hex digit is 
"A"). 

CONTROL WORD FAMILY 

CWO,l - Control word remember controls. 

CMR ■- CW Command register valid. 

DCQ - Disable CLQ (Clear Q). 



QC4 - Remember SIRW. 

RDN - Remember different stack number. 

RFK - Remember to fetch stack. 
RSG - Remember segmented description. 
RVC - Remember VALC. 
ARITHMETIC FAMILY 

ANY - Any 1 in truncated segment. Is there a 
1 in E Truncate which is an extension of the 
"E" Register for arithmetic purposes. 

COF - Carry out. 

GXF - Greater exponent. 

RLM - Right to left mode. 

TRF - Truncate. 

ZRO - Remember zero. 

ZRA - The "A" operand is zero. 

ZRB - The "B" operand is zero. 

ZRR - The result is zero. 

PROGRAM OPERATOR ALGORITHM FLIP-FLOPS 
TIME-SHARED (PQ) - PQ7-0 contain the pro- 
gram operator variants. 

OTHERS 

RFD - Remember flashback for data. 

RNC - Remember concatenated NAMC. 

SNO - Special action if integer overflow. 

SOP - Source is an operand. 

ROW 9 

READ EU STORAGE 

RES 

V - RESV is EU read valid. 

- RESO is read within first 4 words of EU 
storage. 

1 - RESl is read within second 4 words of EU 
storage. 

R - RESR is read within third 4 words of EU 
storage. 
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W - RESW is read within fourth 4 words of 
EU storage. 

REW - REW1,0 contains the EU read ad- 
dress within four word groups. 

PARITY CONTROL 

PLA - PLA2-0 is parity look ahead, a code in- 
dicating what type of parity to check. 

PCH - Parity check. 

STF - Store first time. 
PARITY DATA 

PARITY IN EU STORAGE 

POO-13 - Parity bits for EU local storage in A 
and B areas. 

PWO,l - Time shared "W" Register parity. 

PR - Time shared "R" Register parity. 

ACCUM INPUT PARITY 

PAN - Accumulate indicated parity for "A". 

PBN - Accumulate indicated parity for "B". 
PRN - Accumulate indicated parity for "R". 
PWN - Accumulate indicated parity for "W". 
EXP AND TAG 

PAX - "A" operand exponent indicated parity. 
PBX - "B" operand exponent indicated parity. 
PTA - Tag indicated parity. 

X BUS CONTROLS 

MAX - Main adder Transfer to the X Buss. 

RDJ - Read to "J" storage (auxiliary storage 
location). When reset, read to "H" storage. 

WTH - Write to "H" storage (auxiliary storage 
location). 

WTJ - Write to "J" storage (auxiliary storage 
location). 

FBC - F contains bad C register contents. 

LENGTH REGISTERS 

RL - RL1,0 contains the "R" storage length in 

EU Local storage (in number of words). 



WL - WL1.0 contains the "W" storage length 
in EU Local storage (in number of words). 

WRITE COUNTERS 

RWR - RW1,0 contains the "R" storage write 

counter. 

WWR - The "W" storage write counter. 

WRITE EU STORAGE 

WEAL - Write allow for EU local storage. 

WEW - WEW3-0 contains the write address for 
EU local storage. 

ROW 10 

Q REGISTER (QR30-0) - The Trial Quotent 
Register used in division. 

E TRUNCATE (ET3-1) - The "E" Register 
Truncate bits. 

BLS (BLS1,0) - Contain the binary shift left 
factor for division. 

REMAINDER REGISTER (RM) 

V - RMV is remainder register invalid. 

Bits 40-35 - RM40-35 is the remainder register. 

ADDER CONTROLS 

EAC - End around carry. 

PL1 - Plus 1. 

PL2 - Plus 2. 

SPL1 - Special plus 1, used when a "double 
carry" occurs. 

DECODE CONTROLS 

MP1 - Multiplier plus 1. 

Ml - Mode 1 for the scale right operator. 

MISC ARITH DATA 

DM39 - The "D" Register mantissa bit 39 indi- 
cates overflow from the mantissa into the ex- 
ponent. 

EFH - "E" and "F" Registers exponent hold 
causes the valid bit of the "E" and "F" expo- 
nent register's not to be reset. 

If this command was not issued, the data valid 
bit would normally be automatically reset in 
the next clock eventually resulting in a conti- 
nuity error. 

ESS - EU Local storage Transfer to the "S" 
Buss (The normal Transfer is to the "T" Buss). 

NZG - Zeros were not loaded to the "G" Regis- 
ter. 
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T EXP (TBX1.0) - The "T" Buss back up expo- 
nent used for exponent overflow during arith- 
metic operations. 

C REGISTER STATUS 

ZAP - The number of leading zeros in the "C" 
Register have been counted, and the result 
has been placed in the "A" pointer. 

ZBP - The number of leading zeros in the "C" 
Register have been counted, and the result 
has been placed in the "B" pointer. 

SIC - The contents of the "S" Buss have been 
transferred to the "C" Register. (The normal 
transfer is from the "T" Buss to the "C" Reg- 
ister). 

SPECIAL RESIDUE 

SR - SR1.0 is the special residue for the "C" 

Register mantissa (see CSR). 

BSR - BSR1,0 is residue for current B word in 
local storage. 

SEG COUNTER (SC2-0) - A segment counter 
used to keep track of words, used in conjunc- 
tion with the pointers. 

POINTER UPDATE REGISTERS 

PVL - Pointer update register valid. 

PUD - PUD6-4 is a word update for the EU lo- 
cal storage pointers. 

PUD3-0 is a digit update for the EU local stor- 
age pointers. 

MODES 

PSUB-Subtract pointer update register. 

2WP - Two word mode for pointer update. 

4BM - Four bit mode for EU local storage 
pointers (normally information is dealt with in 
three bit digits). 

ROW 11 

OPERATOR Q READ 

OQO - OQR2-0 is the operator queue read reg- 
ister. 

DATA Q CONTROLS 

DQW - DQW1.0 is the data queue write regis- 
ter. 

WLQ - Write into the least significant word of 
the double precision data queue entry. 

DQR - DQR1,0 is the data queue read register. 



RLQ - Read from the least significant word of 
the double precision data queue entry. 

VALID (DQV3-0). The data queue valid regis- 
ter is used to allow a inhibit reads and writes. 
Each double precision data queue entry is rep- 
resented by a bit in DQV. The bit must be true 
to enable a read and false to enable a write. 

SINGLE PREC (QSP3-0) - Used to indicate 
single precision operand in each of the data 
queue entries. 

DQA - Data queue read pointer advance. 

EU ENABLE (EUE2-1) 

Enables the clock for the EU. 

CONTROL FOR COMMUNICATION WITH OTHER 
UNITS 

CSH - Conditional stack hold. Enables hold for 
stack buffer if necessary. 

HSQ - Hold for Storage unit data queue avail- 
able. 

SDQ - Store to storage unit data queue. 

ERD - EU request for address unit read. 

LDD - EU request for address unit quick 
write. 

EWP - Enable address unit write pointer. 

AHE - Address unit hold and conditional EU 
hold for EWR. 

EHE - EU hold for EWR data valid. 

AHS - Address unit transfers to MAR. 

CSO - "C" Register transfer to MAR. 

ADA - Address of last EU fetch in AU. 

ERW - Unconditional request for EWR. 

ERA - Address unit controlled by EU. 

ERS - EU request for storage unit. 

EHS - EU hold for storage unit available. 

AUH - Address Unit hold. 

DLA - Disable load associative memory. 

1WM - One word mode for string fetching. 
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2WM - Two word mode for string fetching. 

SOURCE PROTECT AND SIZE 

SPR - Source memory protect. 

SS2-0 - The source size register which con- 
tains the character size. 

DESCRIPTOR CONTROL/DESTIN. PROTECT AND SIZE 
ENR - Edit, not return from interrupt. 

DC44 - "D" Control Register bit 44 which indi- 
cates that data is segmented. 

DPR - Destination protect. 

DS2-0 - Destination Size Register which con- 
tains the character size. 



ROW 12 

OPERATOR DELAY REGISTER (OD) 
Bits 4-0 - OD4-0 contain the Operator Delay 
Register which holds the code for an interrupt 
while the existing command is finished. The 
delay is for one clock. 

R - ODR is the operator delay restore bit 
which enables restart of a program operator 
after an interrupt. If ODR is true, then A/B 
Initial will be left as is, however, if ODR is 
false then A/B Initial is moved to A/B Cur- 
rent. 

PU REACT (PU1,0) 

The equivalent of an interrupt caused by a 
series of micro-ops. This mechanism allows 
variation of a micro-op. 

EU REACT 

EUQ - EUQ1,0 is the Eu operator react which 
is the equivalent of an interrupt caused by a 
series of micro-ops. This mechanism allows 
variation of a micro-op. 

EUC - EUC1,0 is the EU command react 
which is similar to EUQ except it allows 
variation of routines. 

BRANCH TYPE 

BRT 

BITS 2-0 - BRT2-0 contain the branch (inter- 
rupt) type. 

R - BRTR is branch type restore. 



EUIT 

EU in Trouble. This mechanism is used for 
synchronization between the EU and PCU and 
is evoked when a change in direction occurs 
and it becomes necessary to call a hardware 
subroutine. 

BTH 

Branch type hold which holds the EU while 
the EU operator queue is invalidated. 

RESIDUE CONTROLS 

4BG - Four bit residue generator mode for 

string operators only. 

WMO - The word residue mode command 
which indicates the type of residue. 

WMS - Word residue check mode. 

SRS - Suppress residue check on sign. 

RESTART STATUS 

SOS - Save old State. 

SOK - State OK. 

NRS - No restart. If set on STOP ON ERROR, 
the micro-op cannot be repeated. 

FAILURE FLIP-FLOPS 

XPL - Extra pointer load which indicates that 
an attempt was made to load a pointer while 
the existing contents were valid. The existing 
pointer information was thus not shifted 
somewhere else before the attempted move, or 
an incorrect hold data valid was issued, or an 
incorrect hold data valid was issued. 



ECF - EU continuity failure. 
ERF - EU residue failure. 
EPF - EU parity failure. 
SMF - String memory failure. 

INTER VARIANTS 

CRL - Created Length. 

LP2 - PCU load P2 if interrupt. 

P2F - P2 contains data. 

QC2 - Inhibit normal interrupt. 
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MISCELLANEOUS EU 

CKC - Check "C" Register continuity. 

FLAG - Remember illegal shift, start, or 
length. 

XGS - Exponent difference greater than se- 
lected leading zeros which indicates that the 
exponent was too large to use only the expo- 
nent shift. 

SGM - Single routine mode. 

EMR - EU force memory reference. 

WAL - "W" Register allocation. 

DSN - DSF (SD1 relative to Dl) next. 

IIH - Inhibit external interrupts (DEXI). 

RXO - Remember exponent overflow. 

EUA-EU Abort. 

OPERAND IDENTITY 

COMMD (CQ1,0) is the command operand 

which acts as a variant on the command. 

STORE (SQ1,0) is the "check" operand which 
acts as a variant on the store. 

ROW 13 

PROCESSOR MISCELLANEOUS 

MSK - Master synchronization flag to keep 8 

and 16 MHz cooperative. 

ZZZ - Used with MDU COMPARE OR and 
MDU COMPARE AND switches. When the 
compare function is satisfied, ZZZ is set to 
stop the 8 and 16 MHz clocks. 

16M - 16 MHz clock. 

08M - 8 MHz clock. 

DLT - Delete T bus. 

RSN - Restart next operator. 

SDW - Store to "D" Register word. 

LD1 - Last Dl valid in AU location 3B. 

39A - 39-bit adder mode. 

SPO - String program operator. 

CLE - Clear EU controls. 



RIN - Repeat instruction. 

RCL - Remember CLQ (clear Q) in EU. 

RQF - Remember quick fetch (for string ops). 

FAS - Fast mode (for long string ops). 

FAL - Fail to stay in Fast Mode. 

FLS - Failsoft (protected write operation in 
memory; bit 48 — 1). 

REMEMBER SUSPEND REGISTER (RS) 

Holds the control word if a multiword fetch 
by the PCU for the program buffer is inter- 
rupted. The PCU has the lowest priority with 
the COMM. Unit. 

LENGTH (RS24-22) - The number of words re- 
maining to be read. 

Comm Address - (RS21-2) - The main memory 
address. 

RES (RS01,0) - Comm address residue. 
ROW 14 - ROW 34 DISPLAY SELECTION 

The fourteenth row of indicators is used to 
display the contents of either row 14 or row 34. 
The selection of the row to be displayed is 
made through use of a toggle switch which is 
located on the right hand side of the panel ad- 
jacent to the fourteenth row of indicators and 
which is labeled FC, P2, CM - OVF, FM, FR. 

ROW 14 

PI SPECIAL 

RT - Return bit for presence bit Pi parameter. 

R45 - Remember RETN bit for presence bit 
PI. 

V39 - Remember VALC bit for presence bit PI. 

EGG/HELP - 8 to 16 second timer; used to get 
out of software loop. 

FAULT CONDITION REGISTER 
SKOF - Stack overflow. 

NTVT - Interval timer. 

PGOP - Programmed operator. 

SEGA - Segmented array. 

SEQ - Sequence error. 
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PBIT - Presence bit. 
BTSK - Bottom of stack. 
NTOF - Integer overflow. 
NVNX - Invalid index. 
XUNF - Exponent underflow. 
XOVF - Exponent overflow. 
DVBO - Divide by zero. 
NVOP - Invalid operant. 
MPRO - Memory protect. 

PINT - Processor internal. 

INVP - Invalid program word. 

SKUF - Stack underflow. 

NAM - Invalid address (no access to memory). 

FAL1 - Memory fail 1 (2 or more bits in error). 

MPAR - Memory parity. 

LOOP - Loop. 

P2 REGISTER (P22-20) 
P2 parameter register for interrupts. 

CONTROL MODES (CM3-0) 

Interrupt management level of the proces- 
sor. 

ROW 34 

FAULT MASK REGISTER - FAIL REGISTER (FM) 

BITS 42-23 - FM42-23 is the Fault Mask Regis- 
ter which enables or disables recognition of 
the special (third Priority) and external 
(fourth priority) interrupts. 

INR - Inhibit normal return. 

MES - Indicates that incorrect data exists for 
restart operation. (Data cannot be recovered.) 

EUC - EU continuity. 

EUR - EU residue. 

EUP - EU parity. 

PER - Program Unit error. 

ADD - Adder unit residue. 

6-22 



WCN - Wrong channel number. 

INP - Parity to the Comm. Unit. 

CRS - Comm. Unit residue. 

CSE - Comm. single error. 

MTO - Memory time out. 

F2 - One bit error. 

SU - Storage Unit. 

SK - Stack. 

OP - Operation. 

MADS5-0 - Memory address for interrupts. 

BN3-0 - Box number for interrupts. 

ROW 15 



TIME OF DAY CLOCK (TD35-0) 
The time of day in 2-microsecond intervals. 

LOOP TIMER (LT11-0) 

A 2-second timer in the processor that is re- 
triggered with the completion of each program 
operator based in Final Command Final Rou- 
tine. 

TIMER CONTROL 

IC1 - Loop timer overflow control. 

LOP - LOOP timer overflow. 
ITZ - Incremental timer zero. 
ARM - Incremental timer overflow. 
PANEL 2 SWITCHES (LEFT-HAND PANEL) 
MDU COMP CONT 

HPIR 

This switch with MDU COMPARE AND 
causes a halt if P1R of an instruction is equal 
to the value selected in MDU toggle switches. 

HSI/HSP 

HSI allows the processor to halt on single in- 
struction; HSP allows the processor to stop on 
a single clock. (This switch is used in conjunc- 
tion with MDU COMPARE AND or MDU 
COMPARE OR.) 



PROGRAM 



PRB 



Used in manually reading and writing the 
program buffer. 

EU STORAGE 

LOC 

Used in manually reading and writing the 
EU Local Storage. 

STACK 

STK 

Used in manually reading or writing the 
stack buffer. 

PRG 

Used with PLS switch to purge the stack 
buffer. This operation also invalidates the 
four-word ASM, if the 4AM switch is in the up 
position. 

ASSOCIATIVE MEMORY 

1AM 

Used in manually reading and writing the 
one-word Associative Memory data. 

4AS 

Used in manually reading and writing the 
four-word Associative Memory data. 

ASM 

Used with 4AM and PLS switches to advance 
MAR count by four. 

1PL 

Used with PLS switch to advance Priority 
List count. 

DISPLAYS 

DSP 

Used in manually reading and writing the 
Display Buffer. 

BUFFER CONTROLS 

R/W 

Used with the other storage controls to des- 
ignate a Read (false) or Write (true) operation. 

PLS 

A momentary contact switch used for puls- 
ing in conjunction with the other local buffer 
controls to actually transfer in or out of the lo- 
cal storage. 

SINGLE PULSE 

ON-OFF 

This indicator/switch enables or disables the 
Single Pulse junction. If this switch is on, the 
Special Function switch must also be on. 



PUSH BUTTON 

Used for single pulsing. When this switch is 
pressed, one 8 MHz and two 16 MHz clocks are 
generated. 

MDU COMPARE OR 

This causes a halt if any bit within a combi- 
nation of bits in the Processor is equal to the 
value selected in MDU toggle switches. 

MDU COMPARE AND 

This causes a halt if a combination of bits in 
the Processor is equal to the value selected in 
MDU toggle switches. 

MDU ENABLE 
Enables communication with the MDU. 

INHIBIT ERROR 

Prevents execution errors from stopping 
unit. 

ERROR STOP 

Stops unit on internal hardware errors. If an 
internal interrupt occurs, bit 6, row 14 is set. 

REPEAT INST 

Causes loop on instruction that caused unit 
to stop on error STOPj. Must be pressed after 
unit has stopped on error. 

SINGLE ROUTINE 

Causes execution of a single routine within 
an instruction. (Execution of single EU 
operator). 

16/8 MHZ-16 MHZ 

In position 16/8 MHZ, an 8-MHz and two 16- 
MHz clocks are generated when panel 1 or 
panel 2 push button is pressed. In position 16 
MHZ, one 16-MHz clock is generated when 
panel 1 or panel 2 push button is pressed. 

CONTROL CLEAR 
General processor clear. 

START 

Starts processor. This switch is also used to 
continue from some types of halt conditions. 

PANEL 1 INDICATORS (RIGHT PANEL) 

COMMUNICATIONS UNIT 

ROW 1 - ROW 21 DISPLAY SELECTION 

The first row of indicators is used to display 
the contents of either row 1 or 21. The selec- 
tion of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the first row of indicators and which is labeled 
IN-OP. 
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ROW 1 



KUL - Stack unit last word. 



INPUT REGISTER (IN51-0) 

The input register to the Comm Unit which 
is used for data transfer between the proces- 
sor and memory. 

ROW 21 

OUTPUT REGISTER (OP51-0) 

The output register from the Comm. Unit 
which is used for data transfer between mem- 
ory and the processor. 

ROW 2 

CHAN SEL REG (CSR4-0) 

Contains the number of the physical MCM 
selected. 

COMM TIMER (CT6-0) 
Timer for Comm Unit operations. 

SU OPERATIONAL CONTROLS 
SA1,0 - Start address. 

CRQ - Comm request data queue. 

CRA - Comm request Associative Memory. 

RDP - Remember double precision. 

CHT - Comm halt. 

ICH - Inhibit comm halt. 

EQE - EWR enable. 

ERRORS 

IVC - Invalid channel. 

INE - Internal error. 

IPE - Input register parity error. 

NAM - No access to memory. 

ERR - Comm error. 

CLN5 

The most significant bit of the comm length 
(CLN) located in row 3, bits 26-22. 

SU CANCEL LENGTH (24-22) 

Used with CLN to determine last memory 
fetch to EWR. 

INTERNAL REQUESTOR INTERFACE 
IGP - Ignore data parity. 

RFR - Request processor fail register. 
KUG - Stack granted. 



SUG - Storage unit granted. 

PUG - Program unit granted. 

RSP - Remember suspended operation. 

PUL - Program unit last word. 

SPEC CONTROLS 

R1W - Remember one word. 

ETS - Error transfer sync. 

MDS - Maintenance diagnostic. 

INCREMENTAL TIMER (IT10-0) 
The interval timer. 

ROW 3 

REQUESTOR INTERFACE 

Internal processor requestors to the Comm 
Unit. 

MCM INTERFACE 

RS - Request special 

REQ - Request 

RQS - Request strobe 

ACK - Acknowledge 

SND - Send data 

DST - Data strobe 

DA - Data available 

DAP - Data present 

RQC - Requestor operation complete 

SR - Send/Receive 

FL1 - Fail one 

FL2 - Fail two 

SU VARIANTS 

EWR - Write into the EU Write Register 
QL1,0 - EU Data Queue location 
CA4 - Comm load of 4 word ASM 
CA1 - Comm load of 1 word ASM 
LFD - Look for double precision 

OP CODE 

RW - Read/Write operation 

TYP - Type 

SW - Single word 

PRT - Protect 

FB - Flashback 

R1L - Requestor inhibit load 

MLL - Memory limit load 

COMM LENGTH 

CLN5 (ROW 3 BIT 31) and CLN4-0 contain 
the length of the operation in words. 

COMM ADDRESS (CA19-0) 
The absolute memory address. 
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STORAGE AND STACK UNITS 

ROW 4 - ROW 24 DISPLAY SELECTION 

The fourth row of indicators is used to dis- 
play the contents of either row 4 or 24. The se- 
lection of the row to be displayed is made 
through use of a toggle switch which is located 
on the right hand side of the panel adjacent to 
the fourth row of indicators and which is la- 
beled SU CONTROL MA - 1AM/S1. 

ROW 4 

SU CONTROLS 

SEN - Storage unit unable 

SMR - Storage unit memory reference 

SBY - Storage unit bypass queue 

SAB - Storage unit abort 

SNF - Storage unit not first word 

SBE - Storage unit busy with Execution Unit 

SEC - Storage unit end conditionally 

SP4-1 - Storage unit timing 

VARIANTS 

SEW - Request EWR 

SQL 1,0 - Location in the EU data queue, 

passed from the PCU. 

S4A - Operation for 4 word ASM 

S1A - Operation for 1 word ASM 

SLD - Look for double precision word 

OP CODE 

SRW - Read/Write (reset for fetch and fetch 

memory fail) 

STY - Type (set for memory fail and multiple 

word store) 

SPT - Protect (set for single word store and 

multiple word store) 

SFB - Flashback (set for single word store and 

read with lock) 

SIL - Requestor inhibit load - Memory limit 

load 

SML - Memory limit load 

SLN2-0 - Number of words to be transferred 

SU MEMORY ADDRESS (MA21-0) 

This register receives the absolute memory 
address from the SU operation queue, AU 
adder output, or the C register in the EU. 
(MA21, 20 are residue bits.) 
ROW 24 

1AM ADDRESS (AD, OEU) 

AD-AD15-8 is Associative Memory addressing 
for local checks. 
OEU - Oldest entry upper 
U02-22 - Upper pointers for loading informa- 
tion into Associative Memory 
CBU - Comm busy with upper portion of Asso- 
ciative Memory 



VLU - The upper Associative Memory is valid 
LCU - Local in upper 

CBL - Comm busy with lower portion of Asso- 
ciative Memory 

VLL - The lower Associative Memory is valid 
LCL - Local in lower 

1AM ADDRESS (AD, OEL) 

AD-AD07-0 is Associative Memory addressing 

for local checks. 

OEL - Oldest entry lower 

L02-00 - Lower pointers for loading informa- 
tion into Associative Memory. 

SU INPUT ADDRESS (S21-0) - This register 
receives the absolute memory address from 
the AU adder output. (S21, S20 are residue 
bits.) 

ROW 5 

SU DATA Q (SD) 

W1-W0 - Write pointer 

R1-R0 - Read pointer 

SU MISC 

QNA - Storage unit data queue 

KLC - Stack local check 

RAS - Remember above S 

SAE - Send address to EWR 

SHC - Storage hold for comm 

CBS - Comm busy with Storage Unit 

SDPO - Storage data queue parity location 
SWL - Storage operation write last 

4AM CONTROL 

4AA1 - 4 word Associative Memory address 
L4A - Local in 4 word ASM 
CHA - Comm has ASM 

4AM PRIORITY LIST (PL5-0) 

Contains 1 of the 64 words in the priority ar- 
ray. This word contains three two bit codes 
which represent the three oldest addresses 
within a selected address block (64 address 
blocks). 

STACK LENGTH REGISTER (KLN5-0) 

Contains the stack buffer length currently in 
use. 

S-REGISTER (SR21-0) 

Contains the main memory address of the 
top of stack. (SR21, 20 are the S register 
residue.) 

ROW 6 

STACK VULNERABILITY REGISTER (KV19-0) 

Contains address of S-4 location in the stack 
buffer. 
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STACK CONTROLS 

KP2-1 - Stack Unit timing 

KC1-0 - Stack command 

KBC - Stack busy with comm 

SBK2-0 - Storage Unit busy with stack 

STACK LINK REGISTER (KL21-0) 

Contains the address for the bottom (or old- 
est) item in the stack buffer. (K21, 20 are the 
KL register residue.) 

ROW 7 

LIMIT OF STACK REGISTER (LOSR21-0) 

Contains the main memory address of the 
maximum limit of the stack's assigned area. 

STACK MISC 

TKV3-0 - Top of stack vulnerability 

MCP - Memory copies present 

TKR - Top of stack read 

TKW - Top of stack write 

KWT - Stack write 

F-REGISTER (FR21-0) 

Contains the address of the current Mark 
Stack Control Word. (FR21, 20 are the F regis- 
ter residue.) 

ADDRESS UNIT 

ROW 8 

ADDRESS UNIT CONTROL 

DTO - Address adder timing 

BYE - E.U. is busy with the address adder. 

BYP - PCU is busy with the address adder. 
- Read cycle 

ACY - Add cycle 

EXC - Extra cycle 

WCY - Write cycle 

SAC - Select address couple which is used with 
a name call or value call. 

AD1 - Add one 

ADW - Adder to Display Write Register. 

CDW - Complement the Display Write Regis- 
ter. 

AUO - Address adder overflow. 

AZF - Address adder output's all zeros. 



EU READ PT (ERP5-0) 

The address adder read pointer for the EU 
which allows the EU to access the addressable 
registers. 

PCU READ PT (PRP5-0) 

The address adder read pointer for the Pro- 
gram Unit which allows the PCU to access the 
addressable registers. 



WRITE PT (DWP5-0) 

The address adder write pointer. Only the 
EU can write into the addressable registers. 

SU INPUT OPERATION 
1AP - Input address present 

1WT - Input wait 

1MR - Input memory reference 

IQL1,0 - The queue location in the EU data 
queue 

ILD - Input look for double precision 
IL2 - Input length two 

SQ OPERATION QUEUE (SQ) 

SQR2-0 - Storage Operator Queue Read point- 
ers. 

SQW2-0 - Storage Operator Queue Write point- 
ers. 

PROGRAM CONTROL UNIT 

ROW 9 - ROW 29 DISPLAY SELECTION 

The ninth row of indicators is used to dis- 
play the contents of either row 9 or row 29. 
The selection of the row to be displayed is 
made through use of a toggle switch which is 
located on the right hand side of the panel ad- 
jacent to the ninth row of indicators and 
which is labeled PUR/PLR/RE/RO - DWR/ 
DRR. 

ROW 9 

PROGRAM UPPER REGISTER (PU21-0) 

Contains the main memory address of the 
next word to be loaded into the Program Buf- 
fer. (PU21, 20 are the Program Upper Register 
residue.) 
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PROGRAM LOWER REGISTER (PL21-0) 

Contains the main memory address of the 
oldest active entry in the Program Buffer. 
(PL21, 20 are the Program Lower Register res- 
idue.) 

READ EVEN (PEB3-0) 

A pointer to the even word in the Program 
Buffer. 

READ ODD (POB3-0) 

A pointer to the odd word in the Program 
Buffer. 

ROW 29 

DISPLAY WRITE REGISTER (DW21-0) 

Input register for all addressable registers. 
The DWR is one of the inputs to the address 
adder and is the location into which the 
"hard" registers are manually read. (DW21, 20 
are the Display Write Register residue.) 

DISPLAY READ REGISTER (DR21-0) 

Output register of the addressable registers. 
(DR21, 20 are the Display Read Register 
residue.) 

ROW 10 

PROGRAM ADDRESS REGISTER (PA21-0) 

Contains the main memory address of pro- 
gram code only when a change of direction oc- 
curs. The address is then transferred to the 
Program Upper Register only if a branch point 
is found to be non-local. (PA21, 20 are the Pro- 
gram Address Register residue.) 



PROGRAM BUFFER CONTROL 
PWP4-0 - Program Write Pointer. 

PWE4, PWE3 - Program Write Edit Pointer. 

BK2-0 - Block pointer 

BR4, BR3 - Branch pointer 

SPF - Stop program fetch 

FNL - Force not local 

TUL - Transfer program upper to program 
lower 

IPU - Increment program upper 

PROK - Program OK (for PA residue check) 

CPA - Count Program Address Register 

RAD8 - Remember adjust by 8 



PR I - Pulse switch flip-flop 
SNC - Sync 

STR - Start 

TIR - Table edit remember 

ERC - Edit read control for Program Buffer. 

EWC - Edit write control for Program Buffer. 

ROW 11 

EDIT CONTROL 

EDT - Processor is in the table option of Edit 

Mode. 

EDS - Processor is in the single option of Edit 
Mode. 

EUP - Edit Mode is in update variation. 

ESM - Edit single micro. 

LEXIC LEVEL (LL4-0) 
Contains the current Lexic Level. 

LLW (LLW4-0) 

The Lex Level write register is the input to 
the Lex Level Queue. 
SAVE SYLL (SSR4-0) 

The Syllable Save Register is used as interim 
storage on transfer from the EU to the PCU 
and is also used to save the normal syllable 
when entering Edit Mode. The Just two bits of 
this register (SSR4, SSR3) are the syllable res- 
idue, and the remaining three bits (SSR2-0) 
contain the syllable. 

DATA Q 

DQMT - Data Queue empty 

QER - E.U. Data Queue error. 

QDV - E.U. Data Queue valid. 

DA1-0 - A two bit index into the EU Data 
Queue. 

QRL - Data Queue Ready Lookout. 
IQV - Inhibit EU Data Queue Valid. 
PCU MISC 
ISO - Inhibit stack overflow 

NPR - Alternate P1R 

CLQ - Clear queue 

RCQ - Remember clear queue 

PLE - Pipe line empty 



6-27 



RESIDUE 

VNRl.O - Variant residue 

AR1.0 - Address couple residue 

PB PARITY BITS 

IEP2-0 - Parity bits for syllables located in the 

IER. 



IDP2-0 - Parity bits for syllables located in the 
IDR. 

RPC 

Remember program count. 

OEA, OEB, OEC 
Odd/even flip-flops or the Program Buffer. 

BARREL SELECT (BS5-0) 
The shift controls for the Program Buffer. 

ROW 12 

ORDER CODE WRITE (OW) 

OW11 (ESA) - Stack location A valid 

WL10 (ESB) - Stack location B valid 

OW09 (RPT) - Request report from Execution 
Unit 

OW08 (1END) - Instruction end 

OW07-00 - Micro operator code 

OKLQ 
OK to load operator queue. 

OQWR 

Operator queue write. 

OW2-0 

Operator queue write pointer. 

V (vector) STK 

RA - Remember A 

RB - Remember B 

HOLD CONDITIONS 

CRE - Comm Unit request for use of the EU 
Queue Write Register (EWR). 

SRE - Storage Unit request for use of the 
EWR. 

ERE - Execution Unit request for use of the 
EWR. 



NOTE 
EWR is the input to the Data 
Queue in the Execution Unit. 



DQF - EU Data queue full. 

PIR - Hold for new PIR 

MRK - EU has completed a Mark Stack 
operation. 

EDN - EU done 

PBB - Program Buffer busy with replenish- 
ment. 

RPA - Reset PWA flip-flop. 

PCU CONT 

Tl - Timing for PCU 

T01-3 - Timing for PCU 

VS1 - Valid storage unit input address 

LSI - Load Storage input register 

CFL - Check for program code loop 

ENB - Enber/Branch 

NCC - Name call concatenate 

IPN - Inhibit program next register count 
PCU ERRORS 

PNE - PIR residue error 

PPE - Program word parity error 

PTG - Program tag error 

NEO - Non-existent operator 



REP COUNT (RPC3-1) 
Extensions of the Phase Counter. 

ROW 13 

SUBROUTINES 

EUT - An EUIT indication in the PCU set by 

the EU so that a hardware subroutine can be 

initiated. 

ACT - Hard routine for re-execution of in- 
structions for interrupts. 

CKL - Length check routine in Vector Mode. 

DOB - Hardware routine for execution of dy- 
namic operand branch. 

EDI - Edit interrupt subroutine. 
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STG - Hardware routine for string operator 
interrupt processing. 

ENT - Hardware routine for Enter Junction 
during an interrupt. 

RAK - React subroutine 

INT - Hardware routine for interrupt han- 
dling. 

LOD - Hardware routine for initialization of 
the Program Buffer. 

ACE - accidental entry 

MOV - Hardware routine to accomplish a 
Move Stack operation. 

PAS - Hardware routine to accomplish a 
Pause Junction. 

BY PASS LB 

PMR - Program memory reference 

OP CONT 

ADP - D8, when set, causes issuance of a 

fetch-to-stack (Pop). 

ADM - DA - When set, causes issurance of a 
push. 

DGC - Disable generation of code 

DEC - Disable communication to the EU 



HOLD LOGIC 

PRE - Program Unit requests use of the 

Execution Unit Write Register. 

LDQ - Load Execution Unit Date Queue. 

HNP - Hold for new PIR. 

HFM - Hold up Program control until Execu- 
tion Unit completes mark. 

RPT - Hold for report from EU. 

INH - Inhibit Program Buffer fetches from 
main memory. 

PBA - Program buffer available. 

PWA - Program Control Unit requests use of 
the address adder. 

HSI - Hold single instruction. 



SWG - Something wrong flip-flop. If set, then 
whatever phase we are in as determined by 
the phase counter becomes a special phase. In 
effect, this causes hesitation in normal 
operation due to an exception condition (two 
sequential string operators). 

BGN - Begin first phase of instruction. 

PHASE COUNTER (PHF-0) 
Indicates phase of the program operator. 

ROW 14 

IE CONTROL 

Instruction Execution Register (IER) Con- 
trol. 

IMA - Intermediate stack condition for the 
"A" operand. 

1MB - Intermediate stack condition for the 
"B" operand. 

DVE - Decode Variant Mode operators in the 
IER. 

DEE - Decorde Edit Mode operators in the 
IER. 

INSTRUCTION EXECUTE REGISTER 
(IER23-0) 

A three syllable register which receives the 
program operator from the IDR and decodes it 
into micro-operators. 

IEA 

Instruction execute allow, when reset, dis- 
ables the decode gates of the Instruction 
Execute register. 

VEC - Vector Mode 

PROGRAM INDEX CURRENT (PC17-0) 

Contains program index value for the word 
currently in the IER which, when added to the 
PBR gives the absolute memory address. 
(PC17, 16 is program index current residue.) 

C SYLL (CS2-0) 
The syllable count for the IER. 

ROW 15 

ID CONTROL 

SKA - Stack location A 

SKB - Stack location B 

DVD - Decode Variant Mode operators in the 
IDR. 
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DED - Decord Edit Mode operators in the 
IDR. 

INSTRUCTION DECODE REGISTER 
(IDR23-0) 

A three syllable register which is normally 
considered to be the "look ahead" station. The 
IDR is decoded for barrel shifts and counts for 
"fast" program operators. A combination of 
IDR and IER action is necessary for the 
"slower" operators. Decoding of the IDR also 
provides the initial set-up for stack mainte- 
nance and determines if an operator occurred 
which requires concatenation. 

IDA 

Instruction decode allow when reset, dis- 
ables the decode gates of the Instruction De- 
code register. 

LID 
Load instruction decode register. 

PROGRAM INDEX NEXT (PN17-0) 

Contains index value for the word currently 
in the IDR, which, when added to the PBR 
gives the main memory address. (PN17, 16 are 
the Program Index Next Residue). 

N SYLL (NS2-0) 
The next syllable count for the IDR. 

PANEL 1 SWITCHES (RIGHT HAND PANEL) 

POWER 

OFF - Removes power from the CPM. 

ON - Applies power to the CPM. 

READY - Indicates that the powering-up se- 
quence is complete. 

STATUS 

ON LINE - The CPM is in on-line operation. 
All control switches, with the exception of 
power, are disabled. 

TEST - The CPM is in Text operation. All con- 
trol switches are enabled. 



TEST 

STORAGE - Sets or resets the flip-flops and 
indicators as specified through the toggle and 
thumb wheel switches. 

LAMP - Sets indicators as specified through 
the thumb wheel switches. 



FANS-FAULTS - Indicates that the CPM has 
sensed a fan failure, and has been 
automatically powered down. 

PAUSE - Sets the CPM to control state, con- 
trol mode 3 in a forced PAUS instruction. 

CLEAR - Zeros the field selected through the 
Thumb Wheel switches. 

PAN - Panel number. 

ROW - Indicator row which is printed on the 
right hand margin of the panel. 

GRP - Group. A normal group (1) consists of 
ten indicators, thus group consists of bits 9- 
0. Group 9 specifies that action will be taken 
on the entire selected row. 

LOAD - The contents of the toggle switches 
will be loaded (OR'd) into the location specified 
through the thumb wheel switches. 



SINGLE PULSE 

ON-OFF - Enables a disables single pulse ac- 
tion. If this switch is on, the Special Function 
switch on panel 1 must also be set. 

PUSH BUTTON - Used for single pulsing. 
When this switch is depressed, one sixteen-me- 
gacycle clock is generated. 

SERIAL MODE 

Causes the unit to wait until the EU com- 
pletes each micro-op before it is given another 
one. The micro-op thus is taken directly from 
the OW Register rather than the E.U. 
Operator Queue. 

CONDITIONAL HALT 

Causes a halt if the conditional halt operator 
occurs. Processing may be continued, depend- 
ent on the situation by pressing the Start 
switch. 

HALT ON SDI 

Causes a halt if Program Index current 
(panel 1 row 14, bits 18-03) is equal to the val- 
ue selected in toggle switches 18-03, and FNL 
(panel 1 row 10, bit 12) is set. 

HALT ON PIR 

Causes a halt if Program Index Current and 
C Syll (panel 1 row 14 Bits 18-0) are equal to 
the value selected in toggle switches 18-0. 
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4AM DISABLE 

Inhibits the use of 4 word Associative 
Memory. 



1AM DISABLE 

Inhibits the use of 1 word Associative 
Memory. 

SINGLE INST 

Allows a single program operator to be 
executed each time Start is depressed. This 
switch is also used to temporarily stop the 
processor. 

REPEAT PROGRAM 

Causes the CPM to cycle through the Pro- 
gram Buffer without obtaining more code 
from main memory. 

CONTROL CLEAR 

Clears all "hard" registers to the reset state. 
START 

Resumes execution after a Halt condition. 



PANEL OPERATIONS 

SETTING/RESETTING OF INDICATORS 

The indicators and their associated flip-flops 
can be manually set or reset either from the 
CPM display panels or from the MDU. Selec- 
tion of a row of indicators and a specific group 
within the row is made through four thumb- 
wheel switches which are located on the bot- 
tom portion of the right hand panel, panel 1. 
The switch allows the selection of a Panel (1 or 
2), Row (1-15, 21-23, 27-29, 34), and Group (0-5, 
9), "Group" is a group of ten indicators num- 
bered from through 6 from right to left. A 
group value of nine indicates that the entire 
row will be acted on. 

Once that the row has been selected, it can 
be modified through the 51 toggle switches at 
the bottom of each panel. The Clear button, lo- 
cated immediately to the left of the Thumb 
Wheel switches, causes zeros to be loaded into 
the selected row. The Load button, located im- 
mediately to the right of the Thumb Wheel 
switches, causes the contents of the toggle 
switches to be "OR"ed with the appropriate 
flip-flops. It is thus necessary to clear an area 
and to load it with new values to RESET a se- 
lected indicator. 



LAMP TEST 



NOTE 
The Lamp Test is used to test the indicators only. The flip-flops associ- 
ated with the indicators are not set. 



1. STATUS SWITCH 

2. TEST (SWITCHES) 

3. THUMB WHEEL SWITCHES 

4. LOAD SWITCH 

5. THUMB WHEEL SWITCHES 

6. LOAD SWITCH 

7. THUMB WHEEL SWITCHES 

8. LOAD SWITCH 

9. THUMB WHEEL SWITCHES 

10. LOAD SWITCH 

11. THUMB WHEEL 
SWITCHES 

12. LOAD SWITCH 

13. THUMB WHEEL 
SWITCHES 

14. LOAD SWITCH 



Place in the TEST position. 

Place the LAMP switch in the ON position. 

Set to Panel = l, Row=N/A, Group=0 

PUSH. Indicators on Panel 1 in toggle switch positions 9-0 of all rows should 
light. 

Set to Panel = l, Row = N/A, Group=l 

Push. Indicators on Panel 1 in toggle switch positions 19-10 of all rows should 
light. 

Set to Panel ==1, Row=N/A, Group =2 

Push. Indicators on Panel 1 in toggle switch positions 29-20 of all rows should 
light. 

Set to Panel = l, Row=N/A, Group=3 

Push. Indicators on Panel 1 in toggle switch positions 39-30 of all rows should 
light. 

Set to Panel = l, Row=N/A, Group=4 

Push. Indicators on Panel 1 in toggle switch positions 49-40 of all rows should 
light. 

Set to Panel=l, Row=N/A, Group=5 

Push. Indicators on Panel 1 in toggle switch positions 51, 50 of all rows should 
light. 



6-31 



15. THUMB WHEEL 
SWITCHES 

16. LOAD SWITCH 

17. THUMB WHEEL 
SWITCHES 

18. LOAD SWITCH 

19. THUMB WHEEL 
SWITCHES 

20. LOAD SWITCH 



21. THUMB WHEEL 
SWITCHES 

22. LOAD SWITCH 

23. THUMB WHEEL 
SWITCHES 

24. LOAD SWITCH 



25. THUMB WHEEL 
SWITCHES 

26. LOAD SWITCH 

27. TEST (SWITCHES) 
STORAGE TEST 



Set to Panel==2, Row=N/A, Group=0 

Push. Indicators on Panel 2 in toggle switch positions 9-0 of all rows should 

light. 

Set to Panel=2, Row=N/A, Group=l 

Push. Indicators on Panel 2 in toggle switch positions 19-10 of all rows should 

light. 

Set to Panel=2, Row=N/A, Group=2 

Push. Indicators on Panel 2 in toggle switch positions 29-20 of all rows should 

light. 

Set to Panel=2, Row=N/A, Group=3 

Push. Indicators on Panel 2 in toggle switch positions 39-30 of all rows should 

light. 

Set to Panel=2, Row=N/A, Group=4 

Push. Indicators on Panel 2 in toggle switch positions 49-40 of all rows should 

light. 

Set to Panel=2, Row=N/A, Group=5 

Push. Indicators on Panel 2 in toggle switch positions 51, 50 of all rows should 

light. 

Return the LAMP switch to the OFF position. 



NOTE 
The Storage Test sets or resets both the indicators and their associated 
flip-flops. It is therefore necessary to either de-commit the CPM before 
the test and re-commit it following the TEST or Halt/Load following the 
TEST. 



1. STATUS SWITCH 

2. SINGLE PULSE (Panel 2) 

3. TEST (SWITCHES) 

4. THUMB WHEEL SWITCHES 

5. PANEL 1 CONTROL CLEAR 

6. PANEL 1 TOGGLE 
SWITCHES 

7. LOAD SWITCH 

8. PANEL 1 CONTROL CLEAR 

9. THUMB WHEEL SWITCHES 

10. PANEL 2 CONTROL 
CLEAR 

11. PANEL 2 TOGGLE 
SWITCHES 

12. LOAD SWITCH 

13. PANEL 2 CONTROL 
CLEAR 

14. TEST (SWITCHES) 

15. SINGLE PULSE (Panel 2) 



Place in the TEST position. 

Place in the ON position. 

Place the SORAGE switch in the ON position. 

Set to Panel=l, Row=N/A, Group=9 

Push. All wired indicators on Panel 1 should be OFF (reset). 

Place all switches in the UP (set) position. 

All wired indicators on panel 1 should be ON (set). 

Push. All wired indicators on panel 1 should be OFF (reset). 

Set to Panel=2, Row=N/A, Group=9. 

Push. All wired indicators on Panel 2 should be OFF (reset). 

Place all switches in the UP (set) position. 

Push. All wired indicators on Panel 2 should be ON (set). 
Push. All wired indicators on Panel 2 should be OFF (reset). 

Restore the STORAGE switch to the OFF position. 
Restore to the OFF position. 



NOTE 

The CPM must now either be re-committed or Halt/loaded. 
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PROGRAM BUFFER OPERATION 

To perform a program write operation, proceed as follows: 



1. STATUS switch (panel 1) 

2. REPEAT PROGRAM switch (panel 1) 

3. PROGRAM (panel 2) 

4. BUFFER CONTROLS (panel 2) 

5. THUMB WHEEL switches 

6. CLEAR switch (panel 1) 

7. Panel 1 toggle switches 



8. LOAD switch (panel 1) 

9. BUFFER CONTROLS (panel 2) 



Place in the TEST position. 

Place in the ON position. 

Place the PRB switch in the up position. 

Place the R/W switch in the down position. 

Set to Panel = 1, Row=0, Group=9. 

Press to clear the INPUT REGISTER (IN). 

Set switches 47-0 in the up position (write one's) for the 
information to be written into the program buffer. Bits 48 and 49 
(tag 3) must be set and bit 51 may be set to obtain good parity 
(odd). 

Press to load the IN register. 

Toggle the PLS switch once to write into the program buffer. 



NOTE 
PWP (1-10-24) should be set to indicate that buffer location one is now 
ready to be written into. Repeat step 9 until all 32 buffer locations are 
written into. 



To perform a program read operation, proceed as follows: 



1. PROGRAM (panel 2) 

2. CONTROL CLEAR (panel 1) 

3. PROGRAM (panel 2) 



Place the PRB switch in the down position. 

Press to clear all hard registers. 

Place the PRB switch in the up position. 



NOTE 

If indicator INH (1- 13-2J .) is not on, perform steps 4 thru 6; otherwise, 
proceed with step 7. INH flip-flop must be set in order to read from the 
program buffer. 



4. THUMB WHEEL switches 

5. Panel 1 toggle switches 

6. LOAD switch (panel 1) 

7. BUFFER CONTROLS (panel 2) 

8. BUFFER CONTROLS (panel 2) 



Set to Panel = l, Rcw=13, Group=9. 

Set switch 21 to the up position. 

INH indicator on panel 1 should be on (set). 

Place the R/W switch in the up position. 

Toggle the PLS switch once to read program buffer location into 
the EWE, register (2-1-00 thru 51). Note that bits 48, 49, and 50 will 
not appear in EWR. 



NOTE 
Read Even pointer PEB (1-9-04) should be set. Repeat step 8 and ob- 
serve that Read Odd pointer POB (1-9-00) is set. Repeat step 8 until all 
32 buffer locations are read into the EWR. PEB and POB will alternate- 
ly count as each buffer location is read. 



9. CONTROL CLEAR (panel 1) 



Press to clear the processor. 
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STACK BUFFER OPERATION 

To perform a stack buffer write operation, proceed as follows: 



1. STATUS switch (panel 1) 

2. SINGLE INST switch (panel 1) 

3. BUFFER CONTROLS (panel 2) 

4. STACK (panel 2) 

5. THUMB WHEEL switches 

6. CLEAR switch (panel 1) 

7. Panel 1 toggle switches 

8. LOAD switch (panel 1) 

9. THUMB WHEEL switches 

10. CLEAR switch (panel 1) 

11. Panel 1 toggle switches 

12. LOAD switch (panel 1) 

13. BUFFER CONTROLS (panel 2) 



Place in the TEST position. 

Place in the ON position. 

Place the R/W switch in the down position. 

Place the STK switch in the up position. 

Set to Panel = l, Row=l, Group=9. 

Press to clear the INPUT REGISTER (IN). 

Set switches 51-0 for the information to be written into the stack 
buffer. Bit 51 must be correctly set to obtain good parity (odd). 

Press to load IN register. 

Set to Panel=l, Row=5, Group=0. 

Press to clear the S-REGISTER (SR). 

Set switches 5-0 to the desired stack buffer address. 

Press to load the address into SR05-0. 

Toggle the PLS switch once to write into the stack buffer. 



NOTE 

The buffer address is incremented after the write occurs; therefore, to 
write the next location, repeat step 13. 



To perform a stack buffer read operation, proceed as follows: 



1. BUFFER CONTROLS (panel 2) 

2. THUMB WHEEL switches 

3. Panel 1 toggle switches 

4. LOAD switch (panel 1) 

5. BUFFER CONTROLS (panel 2) 



Place the R/W switch in the up position. 

Set to Panel = l, Row=5, Group=0. 

Set switches 5-0 to the desired stack buffer address. 

Press to load the address into SR05-0. 

Toggle the PLS switch once to read addressed stack buffer location 

into the IN register. 



NOTE 
The buffer address is incremented after the read occurs; therefore, to 
read the next location, repeat step 5. 

DISPLAY BUFFER OPERATION 

The following registers can be accessed through the Display Buffer: 

Register Usage 

Display Registers 
Source Index Register 
Destination Index Register 
Table Index Register 
Base of Stack Register 

Scratch (Spare Local Storage) 
Program Base Register 
Source Base Register 
Destination Base Register 
Table Base Register 

Current Stack Vector Index 
Current Segment Descriptor Index 
Scratch (Spare Local Storage) 
Alternate D [ ] 
Alternate Program Index Register 

All ones 

Last D [ 1 ] used as SD1 Base 



Address 


Address 


Register 


(Decimal) 


(Hex) 


Name 


0-31 


0-1 F 


D [ N ] 


33 


21 


SIR 


34 


22 


DIR 


35 


23 


TIR 


3 V 


25 


BOSR 


39 


27 


S1LS 


48 


30 


PBR 


49 


31 


SBR 


50 


32 


DBR 


51 


33 


TBR 


53 


35 


SNR 


54 


3(5 


PDR 


55 


37 


S2LS 


56 


38 


ADZ 


57 


39 


APIR 


58 


3 A 


ALL1 


59 


38 


LD1 
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To perform a display write and read operation, proceed as follows: 



1. STATUS switch (panel L) 

2. SINGLE INST switch (panel 1) 

3. DISPLAYS (panel 2) 

4. BUFFER CONTROLS (panel 2) 

5. THUMB WHEEL switches 

6. CLEAR switch (panel 1) 

7. Panel 1 toggle switches 

8. LOAD switch (panel 1) 

9. Panel 1, Row 9-29 selection switch 

10. THUMB WHEEL switches 

11. Panel 1 toggle switches 



Place in the TEST position. 

Place in the ON position. 

Place the DSP switch in the up position. 

Place the R/W switch in the down position. 

Set to Panel = l, Row=8, Group=9. 

Press to clear WRITE PT (DWP) and PCU READ PT (PRP). 

Set switches 19-14 and 27-22 to desired display buffer address. (Use 
same address for both switch settings.) 

Press to load the address information into DWP5-0 and PRP5-0. 

Place in the down position for display of DW and DR. 

Set to Panel = l, Row=29, Group=9. 

Set switches 51-32 in the up position (write one's) for the 
information to be written into DW. 



Press to load the DW register. 

Toggle the PLS switch once and observe that DR contains all one's. 



12. LOAD switch (panel 1) 

13. BUFFER CONTROLS (panel 2) 

EU LOCAL STORAGE OPERATION 

To perform an EU local storage write operation, proceed as follows 



NOTE 
The switch locations given in steps 1 thru 9 and 1 thru 7 are located 
on panel 2 of the CPM. 



1. EU STORAGE 

2. SINGLE ROUTINE switch 

3. BUFFER CONTROL 

4. CONTROL CLEAR switch 

5. START switch 

6. THUMB WHEEL switches 

7. Panel 2 toggle switches 

8. BUFFER CONTROLS 



All 16 locations in the 



Place the LOC switch in the up position. 

Place in the ON position. 

Place the R/W switch in the down position. 

Press to clear the processor. 

Press once to set up CPM for an EU local storage operation. 

Set to Panel=2, Row=21, Group=9. 

Set switches 51-00 in the up position (write one's). 

Toggle the PLS switch once and observe that WEWO is set (2-09-00). 
Repeat this step until the count in the WEW pointer returns to 
zero. 

NOTE 
EU local storage should contain ones. 



9. CONTROL CLEAR switch p ress to clear the processor. 

To perform an EU local storage read operation, proceed as follows: 



1. START switch 

2. BUFFER CONTROLS 

3. BUFFER CONTROLS 

4. BUFFER CONTROLS 

5. BUFFER CONTROLS 

6. BUFFER CONTROLS 

7. BUFFER CONTROLS 

8. BUFFER CONTROLS 



Press once to set up CPM for an EU local storage operation. 

Place R/W switch in up position. 

Toggle the PLS switch once and observe that RES0 is set (2-09-50) 
and C register contains all zero's. 

Toggle the PLS switch once and observe that RES0 remains set, 
REW0 is set, and C register contains all one's (bit 51 is off). 

Toggle the PLS switch until RESR and REW0 are set. Observe that 
C register contains all one's (bit 51 is on). 

Toggle the PLS switch until RESW and REW0 are set. Observe 
that C register contains all one's (bit 51 is off). 

Toggle the PLS switch until RESW, REW0, and REW1 are set. 
Observe that C register contains all one's (bit 51 is on). 

Toggle the PLS switch once and observe that C register contains all 
one's (bit 51 is on). Repeat this step and observe that C register 
contains all one's (bit 51 is off). 
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SECTION 3 



INPUT/OUTPUT MODULE PANELS 



This section presents an overall view of the 
input/output module (IOM) in figure VI-3-1 



and closeup views of the panels of the input/ 
output module in figures VI-3-2 and VI-3-3. 



PANEL 2 



PANEL I 




40902 



Figure VI-3-1. Overall View of IOM 
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INPUT/OUTPUT module 
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Figure VI-3-3. Right-Hand Panel of IOM 



SECTION 4 



MEMORY CONTROL MODULE PANEL 



This section describes the functions and 
uses of the controls and indicators on the pan- 
el of the memory control module (MCM). An 
overall view of the memory control module is 
shown in figure VI-4-1, and a close-up of the 
panel is shown in figure VI-4-2. 




Figure VI-4-1. Overall View of MCM 
ROWS 1 THROUGH 12 

ROW 1 

REQUESTOR 

Stores request signals from requestors for 
evaluation by the priority resolver. 



COM FAILURE INHIBITS 

Used to prevent a requestor from locking up 
the priority resolver if he has sent a request 
without a request strobe or to prevent a re- 
questor from obtaining consecutive services if 
a lower priority requestor is waiting. 

REQUESTOR INHIBIT REG 

Used to lock out certain requestors from ac- 
cess. 

ADDRESS LIMITS 

LOWER 

Contains the most significant six bits of the 
lowest memory address available to the MCM. 
Can be programmatically loaded by a CPM. 

UPPER 

Contains the most significant six bits of the 
highest memory address available to the 
MCM. Can be programmatically loaded by a 
CPM. 



MSU STATUS 

Indicates which of the four possible MSU's 
are available to the MCM. Can be program- 
matically loaded by a CPM. 

ROW 3 

MEMORY BUFFER 

The Memory Buffer Register is a 60-bit buf- 
fer register for data transferred to or from the 
MSU's. Bits 52-59, the error-code check bits 
and overall parity bit, are displayed in Row 12 
of the panel. 

ROW 4 

OUTPUT REGISTER 

The Output Register is used to buffer data 
words that are being transmitted to a reques- 
tor. 

ROW 5 

FAILURE REGISTER 

The Failure Register is used to contain all 
pertinent information necessary to identify 
and define a failure. 
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ROW 6 



ROW 10 



CONTROL WORD REGISTER 

The Control Word Register is used to contain 
the control words transmitted by the reques- 
tor. 

ROW 7 

INPUT REGISTER 

The Input Register is used to temporarily 
buffer words received from a requestor. 



ROW 9 

INTERNAL ERRORS 

Internal Errors Register, used to record in- 
ternal errors detected by the MCM. The errors 
detected are: 

AVE - MSU Availability Error 

DTC - Data Transfer Control (DTC) failure 

DTM - Data Timer failure 

MPG - Parity Generator (MSU Control) failure 

MPE - MSU Parity Error 

ADD - Address Counter failure 

C/G - Checker/Generator failure 

RAV - Read Available failure 

MUA - MSU Unavailable 



DSP 

Data Strobe Problem flip-flop, used to indi- 
cate when too many or too few strobes have 
been sent by requestor. 

OV TIM (0C1, 0C2) 

Overflow Clear Timer, controls the timing 
for clear/release of MCM from operation re- 
quested, due to some lockup type of failure in 
the requested operation. 

CWE 

Control Word Error flip-flop, indicates that 
any of the following errors was detected in the 
control word: 

1. Parity. 

2. Wrong MCM Address. 

3. Illegal Operation. 



EGl 

Indicates that the group 1 area of the Fail 
Register is locked with fail information. 

EG2 

Indicates that the group 2 area of the Fail 
Register is locked with fail information. 

E2B 

Indicates an even number of bits in error in 
the word received from an MSU. 

REQ TIM (RT1, RT2) 

Requestor Timer, used in priority resolution. 
It is initiated each time a new request is made 
to the MCM. 



RQS 



Special Request flip-flop, indicates that a 
CPM is making a special request in order to 
load memory limits or requestor inhibits, or to 
fetch the fail register. This type of operation 
bypasses the requestor inhibits. 

MBY 

MCM Busy flip-flop, used to inhibit access by 
other requestors until all communications for 
the using requestor are complete. 

HLD 

Hold flip-flop, used to allow lockup of the 
MCM whenever the error stop option is in ef- 
fect and certain error conditions occur, or dur- 
ing conditional halt operations. 

DTC 

Data Transfer Control, used for transfer of 
controls and data within the MCM. 



ROW 



Read or Write flip-flop, used as a basic con- 
trol during either a read or write operation. 
Set for a read operation and for the read por- 
tion of a protected write or flashback 
operation. Reset for a write operation. 



MPL 

Memory Buffer Load flip-flop, indicates that 
the memory buffer register is loaded, and is 
used to generate other controls as required by 
the operation being performed. 

IOC 

Input/Output Control flip-flop, used to con- 
trol the direction of data transfer between 
MCM and requestor. Set during read operation 
or read portion of a protected write or flash- 
back operation. Reset during a write 
operation. 
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Figure VI-4-2. Panel of MCM 



PBO 

Presence Bit On flip-flip, indicates that the 
output register is loaded with data during a 
read operation. 

SETUP TIM (ST1, ST2) 

Set-up Timer, used to control initialization of 
any operation within the MCM. 

INC TIM (IT3, IT2, IT1) 

Timing counter used to prevent lock-up of 
MCM for such failures as no read available 
signal from MSU or no data strobe from re- 
questor in N word write type operations. 

READ AVAIL (RAA, RAB, RAC, RAD) 

Read Available register, used to store the 
read available signal transmitted from the se- 
lected MSU. 

ADDR RESIDUE 

Address Residue Counter, used to generate a 
residue from the address field of a control 
word. This residue is then compared to the res- 
idue field of the control word to detect any er- 
ror which may have occurred during the trans- 
fer. 

ROW 11 

ERROR REGISTER 

Indicates errors detected by the error detec- 
tion and correction logic. Each bit indicates an 
error in its respective error correction group. 

FAL 1 (F1C, FIT) 

Controls the transmission and duration of 
the FAIL 1 (irrecoverable failure) signal to the 
requestor. 

MWP 

Memory Word Protected flip-flop, indicates if 
a memory word is protected (bit 48 set) during 
the read portion of a protected write 
operation. 

RPW 

Remember Protected Word flip-flop, used to 
maintain a record that a protected word, 2-bit 
error, or memory parity error was encountered 
during a protected write operation. 

WMW 

Write Multi-Word flip-flop, indicates that 
timing control of a N-length operation is under 
control of the requestor data strobe. 

WPW 

Write Protected Word flip-flop, used to con- 
trol the writing of a protected word back into 
its original location on a protected write 
operation. 



WEN 

Write Enable flip-flop, used to control writ- 
ing of data words into the MSU's. 

DATA TIM (DT1-DT4) 

Data Timer, used to control which MSU is se- 
lected during an operation. 

ER TIM (ETl, ET2) 

Error Timer, used to control single-bit error 
correction, failure recording, and initiation of 
failure reporting. 

WORD CNT (WC6-WC1) 

Word Counter, used to monitor the number 
of words transferred during any N length op- 
eration. 

LOCAL TEST 

STR 

Enables start of any local test operation 
from the START push button on the MCM 
panel. 

ERC 

Allows clear of Fail Register and reset of 
hold condition in error stop mode of operation. 

SYN 

Synchronizes start of any local test 
operation or error clear operation with the 8 
MHZ clock. 

ROW 12 

MEM BUFFER 

Memory Buffer Register, used to buffer data 
transferred to or from the MSU's. This portion 
of the register contains the check bits and 
overall parity bit. Bits 0-51 are displayed on 
Row 3 of the panel. 

FAL 2 (F2C, F2T) 

Controls the transmission and duration of 
the FAIL 2 (recoverable failure) signal to the 
requestor. 

SDO 

Send Data On flip-flop, used to control the 
down counting of the Send Data Counter. 

ROC 

Requestor Operation Complete flip-flop, used 
to control the sending of the Requestor 
Operation Complete signal to the requestor. 

END 

Indicates the end of any operation within 
the MCM that does not require final read tim- 
ing. 
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FIN WR CNT (FW4-FW1) 

Final Write Timer, used to control comple- 
tion of any write operation. 

FIN RD (FR1, FR2) 

Final Read Timer, used to time out the final 
portion of a read operation. 

SEND DATA CNT (SD6-SD1) 

Send Data Counter, used to control the num- 
ber of words requested from the requestor 
during a N-length write operation. It is down 
counted as each data word is sent from the re- 
questor. 

It is loaded from the word length field of the 
control word, limited by the number of MSU's 
available, or limited to one if the address is 
less than eight words from the end of an MSU. 

TBY 

Test Busy signal, acts as local requestor flip- 
flop for local test operation of MCM. 

TDS 

Test Data Strobe flip-flop, provides data 
strobe for local test operation of MCM. 

PCS 

Generates a non-ringing CLEAR signal for 
the MSU's from a push-button source at the 
operator's console. 

SWITCHES AND INDICATORS 

CONDITIONAL HALT ADDRESS SWITCHES 

Select program address to be monitored dur- 
ing any writes into memory. 

CONDITIONAL HALT INHIBIT SWITCHES 
REQUESTOR INHIBIT CONTROL (RIC) 

OFF POSITION 

In conditional halt operation lock up of MCM 
will occur whenever monitored program ad- 
dress is written into. 

ON POSITION 

Selected requestor is allowed to override 
conditional halt operation. 

REQUESTOR NUMBER SWITCHES (RQ4, RQ2, RQ1) 

Select requestor who is allowed to override 
conditional halt operation. 

REQUESTOR INHIBIT SWITCHES 

Sets or resets respective FF's each time: 

1. Power is cycled up in MCM. 

2. CONTROL CLEAR push button is de- 
pressed in local test of MCM. 

3. CLEAR is depressed on operator's con- 
sole. 



ADDRESS LIMITS SWITCHES 

(Lower, Upper, and MSU Status). Same as 
for requestor inhibit switches. 

DATA/CONTROL SWITCHES 

Settings used for control word or write data 
word for local test of MCM. 

POWER ON SWITCH 

Applies power to MCM and MSU's if in re- 
mote. 

POWER OFF SWITCH 

Removes power from MCM and MSU's if in 
remote. 

POWER READY INDICATOR 

Lights at completion of power-on sequence. 

STATUS SWITCH 

ON LINE POSITION 

MCM is in on line operation. All test controls 
disabled. 

TEST POSITION 

MCM is in test operation. All test controls 
may be activated. 

TEST 

LAMP SWITCH 

Enables lamp test of indicators selected by 
the group thumb-wheel switch. 

STORAGE SWITCH 

Enables set of all rows equal to pattern set 
in data/control switches. 

FANS FAULT INDICATOR 

Illuminates if failure of a cooling fan is de- 
tected. If this occurs, the MCM is powered off. 

CHECKER INHIBIT SWITCH 

Inhibits detection of 1-or 2-bit errors when 
on. 

GENERATOR INHIBIT SWITCH 

Inhibits changing of check bits and overall 
parity bit loaded into memory buffer during 
write operations. 

ERROR CLEAR 

Resets the following when depressed: 

1. Failure Register. 

2. Error Group 1 (EG1) FF. 

3. Error Group 2 (EG2) FF. 

4. Hold (HLD) FF. 

PANEL/ROW/GROUP THUMBWHEELS 

PANEL 

Selects panel (set to position 1 for MCM). 
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ROW 
Selects register for loading from data/control 

switches. 



GROUP 

Selects group for loading from data/control 
switches or to test in lamp test. 

CLEAR PUSH BUTTON 

Clears FF's selected by PANEL/ROW/ 
GROUP thumbwheels. 

LOAD PUSH BUTTON 

Load FF's selected by PANEL/ROW/GROUP 
thumbwheels. 

SINGLE PULSE SWITCH 

ON POSITION 

8 MHZ clock disabled within MCM. 

OFF POSITION 8 MHZ clock enabled within MCM. 

SINGLE PULSE PUSH BUTTON 

Generates clock pulse each time push button 
is depressed with SINGLE PULSE switch on. 

CONDITIONAL HALT SWITCH 

Enables conditional halt operation for writes 
into memory. 

ERROR STOP SWITCH 

Enables lock up of MCM for any FAIL1, 
FAIL2 conditions detected (exception - any de- 
tection disabled by requestor error inhibit 
switch or by CHECKER INHIBIT on/off 
switch). 

REQUESTOR ERROR INHIBIT SWITCH 

Disables detection of following errors: 

1. Control Word Parity. 

2. Wrong MCM Address. 

3. Write Data Word Parity Error. 

4. Data Strobe Error. 

TEST OPERATION SWITCH 

LOCAL POSITION 

Enables local testing of the MCM (requestors 
not needed for testing). 

REMOTE POSITION 

Enables remote testing of the MCM (reques- 
tor/requestors needed for testing). 

LOCAL TEST SELECTION 

MCM POSITION 

Enables logic oriented towards testing of the 
MCM. 



MSU POSITION 

Enables logic oriented towards testing of 
MSU's. 

MSU TEST SWITCHES 

ADDRESS HOLD, WORD HOLD 

Single address will be tested within memory. 

ADDRESS HOLD, WORD SEQUENCE 

Allows word to sequence while address is 
held (NOTE - this operation should not be 
used with single MSU). 

ADDRESS SEQUENCE, WORD HOLD 

Allows test to be executed sequentially on 
each address within an MSU. 

ADDRESS SEQUENCE, WORD SEQUENCE 

Allows test to be executed sequentially on 
each address within the memory available to 
the MCM. 

CYCLE SWITCH 

SINGLE POSITION 

Only one cycle of test will be executed each 
time the START push button is depressed. 



CONTINUOUS POSITION 

Test will be executed continuously. 

NOTE 
Termination of continuous cycle 
testing should be accomplished by 
placing the CYCLE switch in the 
SINGLE position. It should never 
be terminated through use of the 
CONTROL CLEAR push button. 



CONTROL CLEAR PUSH BUTTON 
Resets the following when pressed: 

1. All controls. 

2. Control Word Register. 

3. Failure Register. 

Loads the requestor inhibit and memory lim- 
its registers from their respective switches 
when depressed. 

START PUSH BUTTON 

Used to initiate any local test of the MCM. 

MCM PANEL OPERATIONS 

To enable the remaining panel controls the 
STATUS switch must be in the TEST position. 
The panel thumbwheel must be in Position 1, 
since the MCM has only one panel. 
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LAMP TEST 

Turn the LAMP TEST switch on, and place 
all DATA/CONTROL switches in the 1 posi- 
tion. Set the GROUP thumbwheel to the po- 
sition and depress the LOAD push button. 
Flip-flops 0-9 of all rows will light. Stepping 
the GROUP thumbwheel from positions thru 
5 and depressing the LOAD push button at 
each position will cause the indicators in all 
rows to light in groups of 10. 

STORAGE TEST 

Turn on the SINGLE PULSE and STOR- 
AGE TEST switches;, and place all DATA/ 
CONTROL switches in the 1 position. Press 
the CLEAR push button, and all indicators 
should be out. Press the LOAD push button 
and all indicators light except for spare indica- 
tors. 

REGISTER LOADING 

Place the TEST OPERATION switch in LO- 
CAL. Place the ROW thumbwheel in the posi- 
tion corresponding to the row number of the 
register to be loaded. Place the GROUP 
thumbwheel in position 9. Set the desired bit 
configuration into the DATA/CONTROL 
switches. Press the CLEAR push button to 
clear the original contents of the register. 
Press the LOAD push button, and the contents 
of the DATA/CONTROL switches are loaded 
into the selected register. 

SINGLE WORD OPERATIONS (READ OR 
WRITE) 

Position the following switches as indicated: 

STATUS Switch - TEST position 

CHECKER INHIBIT Switch - OFF 

GENERATOR INHIBIT Switch - OFF 

CONDITIONAL HALT Switch - OFF 

ERROR STOP Switch - ON 

REQUESTOR ERROR INHIBIT** Switch - 
OFF 

TEST OPERATION Switch - LOCAL position 

LOCAL TEST SELECTION Switch - MSU po- 
sition 



ADDRESS SEQUENCE/HOLD* Switch - 
HOLD position 



WORD SEQUENCE/HOLD* Switch - HOLD 
position 

CYCLE* Switch - SINGLE position 

SINGLE PULSE Switch - OFF 



Load the Control Word Register with a con- 
trol word indicating the desired operation. The 
ADDRESS field should contain the desired 
memory address and the WORD LENGTH 
field should equal 1. The OPERATION CODE 
field should be set as follows: 



Operation 






Bit 








47 


46 


45 


44 


43 


Single Word Overwrite 
Single Word Overwrite 
with Flashback 


1 
1 






1 

1 








1 


Single Word Fetch 
Single Word Protected 




1 






1 
1 




1 







All remaining bits in the control word should 
be zero. 

For any variation of write, load the Input 
Register with the data word to be written. The 
parity bit should be set correctly for this word. 

Press the START push button. The 
operation will take place. 



CONDITIONAL HALT OPERATION 

The CONDITIONAL HALT switch should be 
turned on, the ERROR STOP and REQUEST 
ERROR INHIBIT switches should be off, and 
the TEST OPERATION switch should be in 
the REMOTE position. The CONDITIONAL 
HALT ADDRESS switches should be set to 
the memory address which is to be monitored 
for write operations. The CONDITIONAL 
HALT INHIBIT switches may be used to al- 
low one requestor to override the conditional 
halt operation. 



*lf the ADDRESS and WORD SEQUENCE/HOLD switches are set to the SEQUENCE position, the indicated 
operation will be repeated for consecutive memory addresses each time the START push button is pressed 

**If the ADDRESS and WORD SEQUENCE/HOLD switches are set to the SEQUENCE position and the CYCLE 
switch is set to the CONT position, the indicated operation will be repeated for all consecutive address to the limit of 
the available memory or until an error is detected. If the REQUESTOR ERROR INHIBIT switch is turned OFF, the 
operation will repeatedly cycle through memory until an error is detected. 
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SECTION 5 



MAINTENANCE DIAGNOSTIC UNIT PANELS 



This section presents an overall view of the and close-up views of the panels of the MDU 

maintenance diagnostic unit in figure VI-5-1, in figures VI-5-2, VI-5-3, and VI-5-4. 
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SYSTEM 
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Figure VI-5-1. Maintenance Diagnostic Unit 
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Figure VI-5-2. System Diagnostic Panel 
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Figure VI-5-3. Card Test Panel 
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APPENDIX A 



ORDER OF MAGNITUDE CHART 



REGISTER 
BIT SET 


DECIMAL 


... 

DECIMAL 
RECIPROCAL 


HEX. 


OCTAL 


BINARY 





1 


1.0 


16° 


8° 


2° 


r i 


2 


0.5 








2 


4 1 


0.25 








3 


8 


0. 125 




8' 


2 3 


4 


16 


0.0625 


I6 1 






5 


' 32 


0.03125 








6 


64 


0.015625 




8 2 


2 6 


7 


128 


0.0078125 








8 


256 


0.00390625 


16^ 






9 


512 


0.001953125 




S i 


h— 2 9 


10 


1024 


0.0009765625 








11 


2048 


0.00048828125 




i. 




12 


4096 


0.000244140625 


16 3 


8^ 


2 U 


13 


8192 


0.0001220703125 








14 
15 


16384 


0.00006 10351 5625 








32768 


0.000030517578125 




8 5-H 


2 15 


16 


65536 


0.0000152587890625 


16** 






17 


131072 


0.00000762939453125 








18 


262144 


O.000OO3814697265625 




8 6 


2 18 


19 


524288 


O.000OO19073486328125 








20 


1048576 


O.OO0OOO9536743164O625 


16 5 






21 
22 


2097152 


0.000000476837158203125 




8/ 


2 21 


4194304 


0.0000002384185791015625 








23 


8388608 


0.0000001 1920928955078125 








16777216 


O.OOOO0O05960464477539O625 


16° 


8 8 


2 24 


25 


33554432 


0.0000000298023223876953125 








26 


67108864 


0.000000014901161 19384765625 








27 


1 3^21 7728 


0.000000007450580596923828125 




8 9 


2 27 


2T 


268435456 


. 00000000372529029846 1 9 1 40625 


16 7 






29 
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—230— 


30 
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8 10 
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429^967296 
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16° 






33 


858S'934592 
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8 n 


2 33 


3? 


171 7S>8691 84 
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35 


34355738368 


0.00000000002910383045673370361328125 




pM 


2 3b 


36 


68715'476736 


O.OO0OOOO0001455191522336685180664O625 


16* 


37 


13743*953 I 72 


0.0000000000072759576 141 8342590332031 25 








38 


274877906944 


. OOOOOOOOOOO36379788O709 1 71 295 1 660 1 5625 








~'c 


549755813887 








2 39 


39 


549755813888 


0.000000000001 81 89894035458564758300781 25 
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* FIRST 39 BITS SET. (MAXIMUM INTEGER VALUE ALLOWED) 
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APPENDIX B 



HEXADECIMAL ADDITION TABLE 



HEXADECIMAL ADDITION TABLE 



+ 
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B 
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1 


2 


3 


4 
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A 
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1 


1 
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A 
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2 
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B 


C 


D 


E 


ir 
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5 
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A 


B 


C 


D 


E 


F 


10 


11 


12 


13 


14 


6 


6 


7 


8 


9 


A 


B 


C 


D 


E 


F 


10 


1 1 


12 


13 


14 
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7 


7 
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A 


B 


C 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


8 


8 


9 


A 


B 


C 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


9 


9 


A 


B 


C 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


A 


A 


[3 


C 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


6 


B 


<: 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


C 


C 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


D 


D 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


1C 


E 


E 


F 


10 


11 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


1C 


ID 


F 


F 


10 


1 1 


12 


13 


14 


15 


16 


17 


18 


19 


1A 


IB 


1C 


ID 


IE 
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APPENDIX C 

HEXADECIMAL TO DECIMAL CONVERSION 

TABLES 



Table A and table B provide for direct conversion from hexadecimal to decimal numbers in 
the range of: 

Hexadecimal 

00000 to FFFFF 

or 

Decimal 

to 1048575 

Table A provides the decimal value of the first two digits of a five-digit hexadecimal number 

(nn ), and the table B provides the decimal value of the last three digits of a five-digit 

hexadecimal number { — NNN). 
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HEXADECIMAL-DECIMAL CONVERSION TABLE A 



X 


Ox 


lx 


2x 


3x 


4x 


5x 








65536 


131072 


196608 


262144 


327680 


1 


4096 


69632 


135168 


200704 


266240 


331776 


2 


8192 


73728 


139264 


204800 


270336 


335872 


3 


12288 


77824 


143360 


208896 


274432 


339968 


4 


16384 


81920 


147456 


212992 


278528 


344064 


5 


20480 


86016 


151552 


217088 


282624 


348160 


6 


24576 


90112 


155648 


221184 


286720 


352256 


7 


28672 


94208 


159744 


225280 


290816 


356352 


8 


32768 


98304 


163840 


229376 


294912 


360448 


9 


36864 


102400 


167936 


233472 


299008 


364544 


A 


40960 


106496 


172032 


237568 


303104 


368640 


B 


45056 


110592 


176 128 


241664 


307200 


372736 


C 


49152 


1 1 4688 


180224 


245760 


311296 


376832 


D 


53248 


118784 


184320 


249856 


315392 


380928 


E 


57344 


122880 


188416 


253952 


319488 


385024 


F 


61440 


126976 


192512 


258048 


323584 


389120 


X 


6x 


7x 


8x 


9x 


Ax 


Bx 





393216 


458752 


524288 


589824 


655360 


720896 


1 


397312 


462848 


528384 


593920 


659456 


724992 


2 


401408 


466944 


532480 


598016 


663552 


729088 


3 


405504 


471040 


536576 


602112 


667648 


733184 


4 


409600 


475136 


540672 


606208 


671744 


737280 


5 


413696 


479232 


544768 


610304 


675840 


741376 


6 


417792 


483328 


548864 


614400 


679936 


745472 


7 


421888 


487424 


552960 


618496 


684032 


749568 


8 


425984 


491520 


557056 


622592 


688128 


753664 


9 


430080 


495616 


561152 


626688 


692224 


757760 


A 


434176 


499712 


565248 


630784 


696320 


761856 


B 


438272 


503808 


569344 


634880 


700416 


765952 


C 


442368 


507904 


573440 


638976 


704512 


770048 


D 


446464 


512000 


577536 


643072 


708608 


774144 


E 


450560 


516096 


581632 


647168 


712704 


778240 


F 


454656 


520192 


585728 


651264 


71 6800 


782336 


X 


Cx 


Dx 


Ex 


Fx 









786432 


851968 


917504 


983040 




1 


790528 


856064 


921600 


987136 






2 


794624 


860160 


925696 


991232 






3 


798720 


864256 


929792 


995328 






4 


8028 16 


868352 


933888 


999424 






5 


806912 


872448 


937984 


1003520 






6 


811008 


876544 


942080 


1007616 






7 


815104 


880640 


946176 


1011712 






8 


819200 


884736 


950272 


1015808 






9 


823296 


888832 


954368 


1019904 






A 


827392 


892928 


958464 


1024000 






B 


831488 


897024 


962560 


1028096 






C 


835584 


901120 


966656 


1032192 









839680 


905216 


970752 


1036288 






E 


843776 


909312 


974848 


1040384 






F 


847872 


913408 


978944 


1044480 
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HEXADECIMAL-DECIMAL CONVERSION TABLE B 



000 





1 


2 


3 


4 


5 


6 


7 


8 


9 


10 


11 


12 


13 


14 


15 


010 


16 


17 


18 


19 


20 


21 


22 


23 


24 


25 


26 


27 


28 


29 


30 


31 


020 


32 


33 


34 


35 


36 


37 


38 


39 


40 


41 


42 


43 


44 


45 


46 


47 


030 


48 


49 


50 


51 


52 


53 


54 


55 


56 


57 


58 


59 


60 


61 


62 


63 


040 


64 


65 


66 


67 


68 


69 


70 


71 


72 


73 


74 


75 


76 


77 


78 


79 


050 


80 


81 


82 


83 


84 


85 


86 


87 


88 


89 


90 


91 


92 


93 


94 


95 


060 


96 


97 


98 


99 


100 


101 


102 


103 


104 


105 


106 


107 


108 


109 


110 


1 11 


070 


112 


113 


114 


115 


116 


117 


118 


119 


120 


121 


122 


123 


124 


125 


126 


127 


080 


128 


129 


130 


131 


132 


133 


134 


135 


136 


137 


138 


139 


140 


141 


142 


143 


090 


144 


145 


146 


147 


148 


149 


150 


151 


152 


153 


154 


155 


156 


157 


158 


159 


0A0 


160 


161 


162 


163 


164 


165 


166 


167 


168 


169 


170 


171 


172 


173 


174 


175 


0B0 


176 


177 


178 


179 


l80 


181 


182 


183 


184 


185 


186 


187 


188 


189 


190 


191 


OCO 


192 


193 


194 


195 


196 


197 


198 


199 


200 


201 


202 


203 


204 


205 


206 


207 


000 


208 


209 


210 


211 


212 


213 


214 


215 


216 


217 


218 


219 


220 


221 


222 


223 


0E0 


224 


225 


226 


227 


228 


229 


230 


231 


232 


233 


234 


235 


236 


237 


238 


239 


0F0 


240 


241 


242 


243 


244 


245 


246 


247 


248 


249 


250 


251 


252 


253 


254 


255 


100 


256 


257 


258 


259 


260 


261 


262 


263 


264 


265 


266 


267 


268 


269 


270 


271 


no 


272 


273 


274 


275 


276 


277 


278 


279 


280 


281 


282 


283 


284 


285 


286 


287 


120 


288 


289 


290 


291 


292 


293 


294 


295 


296 


297 


298 


299 


300 


301 


302 


303 


130 


304 


305 


306 


307 


308 


309 


310 


311 


312 


313 


314 


315 


316 


317 


318 


319 


140 


320 


321 


322 


323 


324 


325 


326 


327 


328 


329 


330 


331 


332 


333 


334 


335 


150 


336 


337 


338 


339 


340 


341 


342 


343 


344 


345 


346 


347 


348 


349 


350 


351 


160 


352 


353 


354 


355 


356 


357 


358 


359 


360 


361 


362 


363 


364 


365 


366 


367 


170 


368 


369 


370 


371 


372 


373 


374 


375 


376 


377 


378 


379 


380 


381 


382 


383 


180 


384 


385 


386 


387 


388 


389 


390 


391 


392 


393 


394 


395 


396 


397 


398 


399 


190 


400 


401 


402 


403 


404 


405 


406 


407 


408 


409 


410 


411 


412 


413 


414 


415 


1AO 


416 


417 


418 


419 


420 


421 


422 


423 


424 


425 


426 


427 


428 


429 


430 


431 


IBO 


432 


433 


434 


435 


436 


437 


438 


439 


440 


441 


442 


443 


444 


445 


446 


447 


ICO 


448 


449 


450 


451 


452 


453 


454 


455 


456 


457 


458 


459 


460 


461 


462 


463 


1D0 


464 


465 


466 


467 


468 


469 


470 


471 


472 


473 


474 


475 


476 


477 


478 


479 


1E0 


480 


481 


482 


483 


484 


485 


486 


487 


488 


489 


490 


491 


492 


493 


494 


495 


1F0 


496 


497 


498 


499 


500 


501 


502 


503 


504 


505 


506 


507 


508 


509 


510 


511 


200 


512 


513 


514 


515 


516 


517 


518 


519 


520 


52! 


522 


523 


524 


525 


526 


527 


210 


528 


529 


530 


531 


532 


533 


534 


535 


536 


537 


538 


539 


540 


541 


542 


543 


220 


544 


545 


546 


547 


548 


549 


550 


551 


552 


553 


554 


555 


556 


557 


558 


559 


230 


560 


561 


562 


563 


564 


565 


566 


567 


568 


569 


570 


571 


572 


573 


574 


575 


240 


576 


577 


578 


579 


580 


581 


582 


583 


584 


585 


586 


587 


588 


589 


590 


591 


250 


592 


593 


594 


595 


596 


597 


598 


599 


600 


601 


602 


603 


604 


605 


606 


607 


260 


608 


609 


610 


611 


612 


613 


614 


615 


616 


617 


618 


619 


620 


621 


622 


623 


270 


624 


625 


626 


627 


628 


629 


630 


631 


632 


633 


634 


635 


636 


637 


638 


639 


280 


640 


641 


642 


643 


644 


645 


646 


647 


648 


649 


650 


651 


652 


653 


654 


655 


290 


656 


657 


658 


659 


660 


661 


662 


663 


664 


665 


666 


667 


668 


669 


670 


671 


2A0 


672 


673 


674 


675 


676 


677 


678 


679 


680 


681 


682 


683 


684 


685 


686 


687 


2B0 


688 


689 


690 


691 


692 


693 


694 


695 


696 


697 


698 


699 


700 


701 


702 


703 


2C0 


704 


705 


706 


707 


708 


709 


710 


711 


712 


713 


714 


715 


716 


717 


718 


719 


2D0 


720 


721 


722 


723 


724 


725 


726 


727 


728 


729 


730 


731 


732 


733 


734 


735 


2E0 


736 


737 


738 


739 


740 


741 


742 


743 


744 


745 


746 


747 


748 


749 


750 


751 


2F0 


752 


753 


754 


755 


756 


757 


758 


759 


760 


761 


762 


763 


764 


765 


766 


767 
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HEXADECIMAL-DECIMAL CONVERSION TABLE B (Cont) 

0123 1 »56789ABCDEF 

300 768 769 770 771 772 773 77^ 775 776 777 778 779 780 781 782 783 

310 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 

320 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 

330 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 

340 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 

350 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 

360 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 

370 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 

380 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 

390 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 

3A0 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 

3B0 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 

3C0 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 

3D0 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 

3E0 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 

3F0 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 

400 1024 1025 1026 1027 1028 1029 1030 1 03 1 1032 1033 1034 1035 IO36 1037 1038 1039 

410 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1 05 1 1052 1053 1054 1055 

420 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 

430 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 IO83 1084 IO85 1086 IO87 

440 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1 V03 

450 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 

460 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 

470 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 

480 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1 1 67 

490 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 

4A0 1184 1185 1186 1187 1188 II89 1190 1191 1192 1193 1134 1195 1196 1197 1198 1199 

4B0 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 

4C0 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 

4D0 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 

4E0 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 

4F0 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 

500 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 

510 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 13H 

520 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 

530 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 

540 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 

550 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 

560 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 

570 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 

580 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 

590 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 

5A0 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 14S3 1454 1455 

5B0 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 

5C0 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 i486 1487 

5D0 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 

5E0 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 

5F0 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 
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600 


1536 


1537 


1538 


1539 


1540 


1541 


1542 


1543 


1544 


1545 


1546 


1547 


1548 


1549 


1550 


1551 


6)0 


1552 


1553 


1554 


1555 


1556 


1557 


1558 


1559 


1560 


1561 


1562 


1563 


1564 


1565 


1566 


1567 


620 


1568 


1569 


1570 


1571 


1572 


1573 


1574 


1575 


1576 


1577 


1578 


1579 


1580 


1581 


1582 


1583 


630 


1584 


1585 


1586 


1587 


1588 


1589 


1590 


1591 


1592 


1593 


1594 


1595 


1596 


1597 


1598 


1599 


640 


1600 


1601 


1602 


1603 


1604 


1605 


1606 


1607 


1608 


1609 


1610 


1611 


1612 


1613 


1614 


1615 


650 


1616 


1617 


1618 


1619 


1620 


1621 


1622 


1623 


1624 


1625 


1626 


1627 


1628 


1629 


1630 


1631 


660 


1632 


1633 


1634 


1635 


1636 


1637 


1638 


1639 


1640 


1641 


1642 


1643 


1644 


1645 


1646 


1647 


670 


1648 


1649 


1650 


1651 


1652 


1653 


1654 


1655 


1656 


1657 


I658 


1659 


1660 


1661 


1662 


1663 


680 


1664 


1665 


1666 


1667 


1668 


I669 


1670 


I671 


1672 


1673 


1674 


1675 


1676 


1677 


I678 


1679 


690 


1680 


1681 


1682 


1683 


1684 


1685 


1686 


I687 


1688 


1689 


1690 


1691 


1692 


1693 


1694 


1695 


6A0 


1696 


1697 


I698 


1699 


1700 


1701 


1702 


1703 


1704 


1705 


1706 


1707 


1708 


1709 


1710 


1711 


6 BO 


1712 


1713 


1714 


1715 


1716 


1717 


1718 


1719 


1720 


1721 


1722 


1723 


1724 


1725 


1726 


1727 


6C0 


1728 


1729 


1730 


1731 


1732 


1733 


1734 


1735 


1736 


1737 


1738 


1739 


1740 


1741 


1742 


1743 


6 DO 


1744 


1745 


1746 


1747 


1748 


1749 


1750 


1751 


1752 


1753 


1754 


1755 


1756 


1757 


1758 


1759 


6E0 


1760 


1761 


1762 


1763 


1764 


1765 


1766 


1767 


1768 


1769 


1770 


1771 


1772 


1773 


1774 


1775 


6F0 


1776 


1777 


1778 


1779 


1780 


1781 


1782 


1783 


1784 


1785 


1786 


1787 


1788 


1789 


1790 


1791 


700 


1792 


1793 


1794 


1795 


1796 


1797 


1798 


1799 


1800 


1801 


1802 


1803 


1804 


1805 


1806 


1807 


7)0 


1808 


1809 


1810 


1811 


1812 


1813 


1814 


1815 


1816 


1817 


1818 


1819 


1820 


1821 


1822 


1823 


720 


1824 


1825 


1826 


1827 


1828 


1829 


I830 


1831 


I832 


1833 


1834 


1835 


1836 


1837 


I838 


1839 


730 


1840 


1841 


1842 


1843 


1844 


1845 


1846 


1847 


1848 


1849 


1850 


1851 


1852 


1853 


1854 


1855 


740 


1856 


1857 


1858 


1859 


1860 


1861 


1862 


I863 


1864 


1865 


1866 


I867 


1868 


1869 


1870 


1871 


750 


1872 


1873 


1874 


1875 


1876 


1877 


1878 


1879 


1880 


1881 


1882 


1883 


1884 


1885 


1886 


1887 


760 


1888 


1889 


1890 


1891 


1892 


1893 


1894 


1895 


1896 


1897 


1898 


1899 


1900 


1901 


1902 


1903 


770 


1904 


1905 


1906 


1907 


1908 


1909 


1910 


1911 


1912 


1913 


1914 


1915 


1916 


1917 


1918 


1919 



780 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 

790 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1959 1950 1951 

7A0 1952 1953 1954 1955 1956 1957 1958 1959 I960 1961 1 962 1963 1964 1965 1966 1967 

7B0 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1 982 J 983 

7C0 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 

7D0 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 

7E0 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 

7F0 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 

800 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 

810 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 

820 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 

830 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 

840 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 

850 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 

860 2144 2145 2146 2147 2148 2149 2 1 50 2151 2152 2153 2154 2155 2 1 56 2157 2158 2159 

870 2160 2161 2162 2163 2164 2165 2166 2 1 67 2168 2169 2170 2171 2172 2 1 73 2174 2175 

880 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 

890 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 

8A0 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222 2223 

8B0 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 

8C0 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 

8D0 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 

8E0 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 

8F0 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 
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HEXADECIMAL-DECIMAL CONVERSION TABLE B (Cont) 

0123'»56789ABCDEF 

900 230*4 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 

9)0 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 

920 2336 2337 2338 2339 2340 2341 2342 23*i3 2344 2345 2346 2347 2348 2349 2350 2351 

930 2352 2353 2354 2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 

940 2368 2369 2370 2371 2372 2373 2374 2375 2376 2377 2378 2379 2380 2381 2382 2383 

950 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 

960 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412 2413 2414 2415 

970 2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430 2431 

980 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 

990 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 

9A0 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 

9B0 2480 2481 2482 2483 2484 2485 2486 2487 2488 2489 2490 2491 2492 2493 2494 2495 

9C0 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511 

9D0 2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 

9E0 2528 2529 2530 2531 2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 

9F0 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 

A00 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 

A10 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 

A20 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 

A30 2608 2609 2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 

A40 2624 2625 2626 2627 2628 2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 

A50 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 

A60 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 267 1 

A70 2672 2673 2674 2675 2676 2677 2678 2679 2680 2681 2682 2683 2684 2685 2686 2687 

A80 2688 2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 

A90 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 

AAO 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 

ABO 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 

ACO 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 

ADO 2768 2769 2770 2771 2772 2773 2774 2775 2776 2777 2778 2779 2780 2781 2782 2783 

AEO 2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 

AFO 2800 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810 2811 2812 2813 2814 281 5 

BOO 2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829 2830 2831 

BIO 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 

B20 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 

B30 2864 2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 

B40 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 

B50 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 

B60 2912 2913 2914 2915 2916 2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 

B70 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 

B80 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 

B90 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 

BAO 2976 2977 2978 2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 

BBO 2992 2993 2994 2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 

BCO 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 

BDO 3024 3025 3026 3027 3028 3029 3030 3031 3032 3033 3034 3035 3036 3037 3038 3039 

BEO 3040 3041 3042 3043 3044 3045 3046 3047 3048 3049 3050 3051 3052 3053 3054 3055 

BFO 3056 3057 3058 3059 3060 3061 3062 3063 3064 3065 3066 3067 3068 3069 3070 3071 
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COO 3072 3073 3074 3075 3076 3077 3078 3079 3080 3081 3082 3083 3084 3085 3086 3087 

CIO 3088 3089 3090 3091 3092 3093 3094 3095 3096 3097 3098 3099 3100 3101 3102 3 1 03 

C20 3104 3105 3106 3107 3108 3109 3110 3111 3112 3113 3114 3115 3116 3117 3118 3119 

C30 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 




C80 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 

C90 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226 3227 3228 3229 3230 3231 

CA0 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 

CBO 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 

CCO 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275 3276 3277 3278 3279 

CDO 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 

CEO 3296 3297 3298 3299 3300 3301 3302 3303 3304 3305 3306 3307 3308 3309 3310 33)1 

CFO 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 3327 

DOO 3328 3329 3330 3331 3332 3333 3334 3335 3336 3337 3338 3339 3340 3341 3342 3343 

DIO 3344 3345 3346 3347 3348 3349 3350 3351 3352 3353 3354 3355 3356 3357 3358 3359 

D20 3360 3361 3362 3363 3364 3365 3366 3367 3368 3369 3370 3371 3372 3373 3374 3375 

030 3376 3377 3378 3379 3380 3381 3382 3383 3384 3385 3386 3387 3388 3389 3390 3391 

040 3392 3393 3394 3395 3396 3397 3398 3399 3400 3401 3402 3403 3404 3405 3406 3407 

050 3408 3409 3410 3411 3412 3413 3414 3415 3416 3417 3418 3419 3420 3421 3422 3423 

060 3424 3425 3426 3427 3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439 

070 3440 3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454 3455 

D80 3456 3457 3458 3459 3460 3461 3462 3463 3464 3465 3466 3467 3468 3469 3470 3471 

090 3472 3473 3474 3475 3476 3477 3478 3479 3480 3481 3482 3483 3484 3485 3486 3487 

DAO 3488 3489 3490 3491 3492 3493 3494 3495 3496 3497 3498 3499 3500 3501 3502 3503 

DBO 3504 3505 3506 3507 3508 3509 3510 3511 3512 3513 3514 3515 3516 3517 3518 3519 

DCO 3520 3521 3522 3523 3524 3525 3526 3527 3528 3529 3530 3531 3532 3533 3534 3535 

DDO 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 

DEO 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565 3566 3567 

DFO 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 

EOO 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598 3599 

E10 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 36II 3612 3613 3614 3615 

E20 36I6 3617 3618 3619 3620 3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 363 1 

E30 3632 3633 3634 3635 3636 3637 3638 3639 3640 3641 3642 3643 3644 3645 3646 3647 

E40 3648 3649 3650 3651 3652 3653 3654 3655 3656 3657 3658 3659 3660 3661 3662 3663 

E50 3664 3665 3666 3667 3668 3669 3670 3671 3672 3673 3674 3675 3676 3677 3678 3679 

E60 3680 3681 3682 3683 3684 3685 3686 3687 3688 3689 3690 3691 3692 3693 3694 3695 

E70 3696 3697 3698 3699 3700 3701 3702 3703 3704 3705 3706 3707 3708 3709 3710 3711 

E80 3712 3713 3714 3715 3716 3717 3718 3719 3720 3721 3722 3723 3724 3725 3726 3727 

E90 3728 3729 3730 3731 3731 3733 3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 

EAO 3744 3745 3746 3747 3748 3749 3750 3751 3752 3753 3754 3755 3756 3757 3758 3759 

EBO 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775 

ECO 3776 3777 3778 3779 3780 3781 3782 3783 3784 3785 3786 3787 3788 3789 3790 3791 

EDO 3792 3793 3794 3795 3796 3797 3798 3799 3800 38OI 3802 3803 3804 3805 3806 3807 

EEO 3808 3809 3810 38II 3812 3813 3814 381 5 3816 3817 38 18 3819 3820 3821 3822 3823 

EFO 3824 3825 3826 3827 3827 3829 3830 3831 3832 3833 3834 3835 3836 3837 3838 3839 
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F00 3840 3841 38A2 38^3 3844 3845 3846 3847 3848 3849 3850 3851 3852 3853 3854 3855 

F10 3856 3857 3858 3859 3860 3861 3862 3863 3864 3865 3866 3867 3868 3869 3870 3871 

F20 3872 3873 3874 3875 3876 3877 3878 3879 3880 3881 3882 3883 3884 3885 3886 3887 

F30 3888 3889 3890 3891 3892 3893 3894 3895 3896 3897 3898 3899 3900 3901 3902 3902 

F40 3904 3905 3906 3907 3908 3909 3910 3911 3912 3913 3914 3915 3916 3917 3918 3919 

F50 3920 3921 3922 3923 3924 3925 3926 3927 3928 3929 3930 3931 3932 3933 3934 3935 

F60 3936 3937 3938 3939 3940 3941 3942 3943 3944 3945 3946 3947 3948 3949 3950 3951 

F70 3952 3953 3954 3955 3956 3957 3958 3959 39&0 3961 3962 3963 3964 3965 3966 3967 

F80 3968 3969 3970 3971 3972 3973 3974 3975 3976 3977 3978 3979 3980 3981 3982 3983 

F90 3984 3985 3986 3987 3988 3989 3990 3991 3992 3993 3994 3995 3996 3997 3998 3999 

FA0 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014 4015 

FBO 4016 4017 4018 4019 4020 4021 4022 4023 4024 4025 4026 4027 4028 4029 4030 4031 

FCO 4032 4033 4034 4035 4036 4037 4038 4039 4040 4041 4042 4043 4044 4045 4046 4047 

F00 4048 4049 4050 4051 4052 4053 4054 4055 4056 4057 4058 4059 4060 4061 4062 4063 

FEO 4064 4065 4066 4067 4068 4069 4070 4071 4072 4073 4074 4075 4076 4077 4078 4079 

FFO 4080 4081 4082 4083 4084 4085 4086 4087 4088 4089 4090 4091 4092 4093 4094 4095 
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DECIMAL-HEXADECIMAL CONVERSION TABLE 



DECIMAL-HEXADECIMAL CONVERSION TABLE 



(DECIMAL = Hx16') 



H 
t 


I— 6 


5 


4 


3 


2 


1 





l 


167772I6 


1048576 


65536 


4096 


256 


16 


1 


2 


33554432 


2097152 


131072 


8192 


512 


32 


2 


3 


503316^8 


3145728 


196608 


12288 


768 


48 


3 


4 


67108864 


4194304 


262144 


16384 


1024 


64 


4 


5 


83886080 


5242880 


327680 


20480 


1280 


80 


5 


6 


103663296 


6291456 


393216 


24576 


1536 


96 


6 


7 


117440512 


7340032 


458752 


28672 


1792 


112 


7 


8 


134217728 


8388608 


524288 


32768 


2048 


128 


8 


9 


150994944 


9437184 


589824 


36864 


2304 


144 


9 


A 


167772 160 


10485760 


655360 


40960 


2560 


160 


10 


B 


184549376 


11534336 


720896 


45056 


2816 


176 


11 


c 


201326592 


12582912 


786432 


49152 


3072 


192 


12 


D 


218103808 


13631488 


851968 


53248 


3328 


208 


13 


E 


234881024 


1 4680064 


917504 


57344 


3584 


224 


14 


F 


25 658240 


15728640 


983040 


61440 


3840 


240 


15 



HEXADECIMAL TO DECIMAL 



DECIMAL TO HEXADECIMAL 



3 F 5 



768- 
240- 



5*- 



16 



1013, 



10 



1013 

- 768 
245 

- 240 

5 



10 



3 f 5 



116 



Hexadecimal to Decimal. Find the decimal value for each hexadecimal digit according to its 
position. Add these to obtain the decimal equivalent. 

Decimal to Hexadecimal. Find the next lower decimal number and its Hexadecimal 
equivalent. Subtract and use difference to find the next decimal value and hexadecimal 
equivalent until the complete number is developed. 
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APPENDIX E 
COLLATING INFORMATION 



All characters are collated according to their internal binary value. Because the B 7700 has 
the capability of representing characters internally in BCL, EBCDIC, or USASCII and because 
characters are collated according to their internal representation (not necessarily the same as 
their external mode a variety of collating sequences is possible. The following table may be 
used to determine the applicable collating sequence. 



Input Mode 


Output Mode 


Interna] Mode 


Collating Sequence 


BCL 


BCL 


BCL 


BCL (BCL internal) 


BCL 


EBCDIC 


EBCDIC 


BCL Translated to EBCDIC 


BCL 


BCL 


EBCDIC 


BCL Translated to EBCDIC 


EBCDIC 


EBCDIC 


EBCDIC 


EBCDIC 


EBCDIC 


BCL 


EBCDIC 


BCL Translated to EBCDIC 


EBCDIC 


USASCI 1 


EBCDIC 


USASCII Translated to EBCDIC 


USASCI 1 


USASCI 1 


USASCI 1 


USASCII 


USASCI 1 


EBCDIC 


EBCDIC 


USASCII Translated to EBCDIC 


USASCI 1 


BCL 


USASCI 1 


BCL Translated to USASCII 


USASCI 1 


EBCDIC | 


USASCI 1 


USASCII Translated to EBCDIC 



CHARACTER REPRESENTATION 

The BCL, EBCDIC, and USASCII graphics are the same except as follows: 



SCL 




EBCDIC 




USASCI 1 


— 




1 (single 


quote) 


' 


X 


(multiply/ 


! or | or 


MZ 


} 


<_ 




-i (not) 




- 


* 




(underscore) 




-«- 




I (or) 




i 


+ 




PZ (+) 




{ 


i 




< 






j 




> 






< 




+ 







E-1 



A BCL plus sign is never translated to an EBCDIC PZ (plus zero) sign, although the EBCDIC 
PZ is translated to a BCL plus sign. 

EBCDIC 1110 0000 is translated to BCL 00 0000 with an additional flag bit on the next to 
most significant bit line (7th bit). As the print drums have 64 graphics and space this signal 
can be used to print the 64th graphic. The 64th graphic is a "CR" for BCL drums and a"i 
for EBCDIC drums. 

COLLATING SEQUENCES 



EBCDIC 




USASCI 1 




BCL 




n n r\ 




r\ r 


-^ r\ 




r~\ 




NUL 


+ 


r 


1 




NUL 


I 


N 


u 




P 


:* 


S0H 


| 


s 


2 




S0H 


( 





V 




1 


0. 


o 

—J 


STX 


£ 


t 


3 




STX 


) 


P 


w 




2 


R 


A 


ETX 


] 


u 


it 




ETX 


■k 


Q 


X 




3 


$ 




HT 


$ 


V 


5 




EOT 


+ 


R 


y 




A 


* 




DEL 


J~ 


w 


6 




ENQ 


i 


S 


z 




5 


- 




VT 


) 


X 


7 




ACK 


- 


T 


{ 




6 


) 




FF 


9 


y 


8 




BEL 


• 


U 


1 

1 




7 


» 




CR 




z 


9 




BS 


/ 


V 


} 




8 


< 




SO 


- 


PZ 






HT 





w 


•V/ 




q 


(Blank) 




SI 


1 


A 






LF 


1 


X 


DEL 




# 


/ 




DLE 


> 


B 






VT 


2 


Y 






§ 


S 




DC1 


X 


C 






FF 


3 


z 






? 


T 




DC2 





D 






CR 


k 


[ 






: i 


U 




DC3 


> 


E 






SO 


5 


\ 






> 


V 




NL 


? 


F 






SI 


6 


] 






> 


W 




BS 


: 


G 






OLE 


7 


A 






+ 


X 




CAN 


# 


H 






DC1 


8 


- 






A 


Y 




EM 


6 


1 






DC 2. 


9 


\ 






B 


Z 




FS 


i 


MZ(!) 






DC3 


: 


a 






C 


f 




GS 


= 


J 






OCA 


i 


b 









% 




RS 


ti 


K 






NAK 


< 


c 






E 


it 




US 


a 


L 






SYN 


s 


d 






F 


e: 




LF 


b 


M 






ETB 


> 


e 






G 


] 




ETB 


c 


N 






CAN 


? 


f 






H 


It 




ESC 


d 









EM 


e 


9 






1 






ENQ 


e 


P 






SUB 


A 


h 






• 






ACK 


f 


0. 






ESC 


B 


i 






[ 






BEL 


9 


R 






FS 


C 


J 






t 






SYN 


h 


\ 






GS 


D 


k 






( 






EOT 


i 


S 






RS 


E 


1 






< 






DCi 


J 


T 






US 


F 


m 






■♦- 






NAK 


k 


U 






SP 


G 


n 






X 






SUB 


1 


V 






1 


H 









J 






SP 


m 


w 






II 


1 


P 






K 






[ 


n 


X 






g 


J 


q 






L 




' 







Y 






$ 


K 


r 






M 




3 


< 


P 


z 






* 


L 


s 






N 




a 


( 0^ 


o 




KJ "J \J 


■■ 


•vJ 





E-2 



EBCDIC 


Hex. 


Internal 


Card Code 


Character 


Code 


Code 


Zone Number 


NUL 


OO 


0000 0000 


12-0-9- 8-1 


SOH 


01 


r\r\r\r\ nnp i 

VVWW WV 1 


12-9- 1 


STX 


02 


0000 0010 


12-S- 2 


ETX 


03 


0000 0011 


12-9- 3 


HT 


05 


0000 0101 


12-9- 5 


DEL 


07 


0000 0111 


12-9- 7 


VT 


OB 


0000 1011 


12-9- 8-3 


FF 


OC 


0000 1100 


12-9- 8-4 


CR 


00 


0000 1101 


12-9- 8-5 


SO 


ut 


OOUO 1 1 10 


12-9- 5-6 


SI 


OF 


0000 1 1 1 1 


12-9- 8-7 


DLE 


10 


000! 0000 


12-11-9- 8-1 


DC1 


11 


0001 0001 


11-9- 1 


DC 2 


12 


0001 0010 


11-9- 2 


DC3 


13 


0001 0011 


11-9- 3 


NL 


15 


0001 0101 


11-9 5 


BS 


16 


0001 0110 


11-9- 6 


CAN 


18 


0001 1000 


11-9- 8 


EM 


19 


0001 1001 


11-9- 8-1 


FS 


1C 


0001 1100 


11-9- 8-4 


GS 


10 


0001 1101 


11-9- 8-5 


RS 


IE 


0001 1110 


11-9- 8-6 


US 


IF 


oooi nn 


11-9- 8-7 


IF 


25 


0010 0101 


0-9- 5 


ETB 


26 


0010 0110 


0-9- 6 


ESC 


27 


0010 0110 


0-9- 7 


ENQ 


20 


r\f\ i A iiai 

uy iy i iui 


n n O r- 


ACK 


2E 


0010 1110 


0-9- 8-6 


BEL 


2F 


0010 1111 


0-9- 8-7 


SYN 


32 


0011 0010 


9- 2 


EOT 


37 


0011 0111 


9- 7 


DC4 


3C 


0011 1100 


9- 8-4 


NAK 


30 


nn 11 1 1 n 1 
UU 1 1 1 1 U 1 


9- 8-5 


SUB 


3F 


oon nn 


9- 8-7 


SP 


40 


0100 0000 


(No Punches) 


[ 


4A 


0100 1010 


12- 8-2 


. 


4B 


0100 1011 


12- 8-3 


< 


4C 


0100 1100 


12- 8-4 


( 


4d 


0100 1101 


12- 8-5 


+ 


4E 


0100 1110 


12- 8-6 


| M 


4F 


oioo nn 


12- 8-7 



o 



EBCDIC 


Hex. 


Internal 


Car 


d Code 


Character 


Code 


Code 


Zone 


Number 


6 


50 


0101 0000 


12- 


_ 


1 
J 


5A 


OiOl 1010 


1 1- 


8-2 


$ 


5B 


0101 1011 


1 1- 


8-3 


j. 


5C 


0101 1100 


1 1- 


8-4 


) 


5D 


0101 1101 


1 1- 


8-5 


I 


5E 


0101 1110 


1 1- 


8-6 


— i (<) 


5F 


oioi nn 


1 1- 


8-7 


- (Dash) 


60 


0110 0000 


11- 


. 


/ 


61 


0110 0001 


0- 


1 


. (Comma) 


6B 


0110 1011 


0- 


8-3 


% 


6C 


0110 1100 


0- 


8-4 


W 


60 


0110 1101 


r\ _ 


8-5 


> 


6E 


0110 1110 


0- 


8-6 


? 


6F 


ono nn 


0- 


8-7 




7A 


0111 1010 


_ 


8-2 


# 


7B 


oni ion 


- 


8-3 


e 


7C 


0111 1100 


- 


8-4 


• U) 


7D 


0111 1101 


- 


8-5 


- 


7E 


0111 1110 


- 


8-6 


u 


7F 


oni nn 


- 


8-7 


a 


81 


1000 0001 


12-0 


1 


b 


82 


1000 0010 


12-0 


2 


c 


83 


iooo oon 


12-0 


3 


d 


84 


innn ninn 


l o_r\ 


j, 






l««W W 1 V w 


i *. \j 


i 


e 


85 


1000 0101 


12-0 


5 


f 


86 


1000 0110 


12-0 


6 


g 


87 


1000 0111 


12-0 


7 


h 


88 


1000 1000 


12-0 


8 


i 


89 


1000 1001 


12-0 


9 


J 


91 


1001 0001 


12-1 


1 


k 


92 


1001 0010 


12-1 


2 


1 


93 


iooi oon 


12-1 


3 


m 


94 


1001 0100 


12-1 


4 


n 


95 


1001 0101 


12-1 


5 





96 


1001 01 10 


12-1 


6 


P 


97 


iooi on i 


12-1 


7 


q 


98 


1001 1000 


12-1 


8 


r 


99 


1001 1001 


12-1 


9 



o 



m 

CD 

O 

o 

o 

o 
o 



o 

CO 

m 
O 

c 
m 
z 
o 
m 



EBCDIC COLLATING SEQUENCE (Cont) 



EBCDIC 
Character 



(+) 



s 

t 
u 

V 

w 

X 

y 

z 

PZ 

A 
B 
C 

D 
E 

F 
G 

H 

I 

MZ 

J 

K 

L 

M 

N 



P 

Q 

R 



\ (CR) (<) 
S 

T 
U 
V 
W 
X 
Y 
Z 



(!) 



Hex. 
Code 



A2 
A3 
A<4 
A5 
A6 
A7 
A8 
A9 

CO 
CI 
C2 
C3 
Ct 
C5 
C6 
C7 

C8 
C9 
DO 
Dl 
D2 
D3 

D5 
D6 
D7 
D8 
D9 

E0 
E2 
E3 
E*t 
E5 
E6 
E7 
E8 
E9 



I nternal 
Code 



1010 
1010 
1010 
1010 
1010 
1010 
1010 
1010 

1100 
1100 
1100 
1100 
1100 
1100 
1100 
1100 

1100 
1100 
1101 
1101 
1101 
I 101 

I 101 
1101 
1101 
1101 

noi 

1101 

II 10 
1110 
1110 
1110 
1110 
1110 
1110 
1110 
1110 



0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 

0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 

1000 
1001 
0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 

0000 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 



Card Code 
Zone Number 



11-0- 
11-0- 
11-0- 
11-0- 
11-0- 
11-0- 
11-0- 
11-0- 

12-0 

12- 

12- 

12- 

12- 

12- 

12- 

12- 

12- 

12- 



0- 
0- 
0- 
0- 

o- 

0- 
0- 
0- 
0- 



1 

2 
3 
k 
5 
6 
7 

8 
9 

1 
2 
3 
k 
5 
6 
7 
8 
9 

8-2 
2 
3 

k 

5 

6 

7 



EBCDIC 


Hex. 


1 nternal 


Card Code 


Character 


Code 


Code 


Zone Number 





F0 


1 1 1 1 0000 





1 


Fl 


1111 0001 


1 


2 


F2 


1111 0010 


2 


3 


F3 


1111 0011 


3 


k 


Fk 


mi oioo 


k 


5 


F5 


mi oioi 


5 


6 


F6 


mi ono 


6 


7 


F7 


nn oin 


7 


8 


F8 


mi looo 


8 


9 


F9 


nn looi 


9 

_ 



E-4 



BCL COLLATING SEQUENCE (BCL INTERNAL) 













BCL 




BCL 


BCL 


BCL 


BCL 


1 nterna 1 


External 


Card Code 


Character 


Octal 


Hex 


BA 


8421 


BA 8421 


Zone Number 

















00 


00 


00 


0000 


00 1010 





1 


01 


01 


00 


0001 


00 0001 


1 


2 


02 


02 


00 


0010 


00 0010 


2 


3 


03 


03 


00 


0011 


00 0011 


3 


4 


04 


04 


00 


0100 


00 0100 


4 


5 


05 


05 


00 


0101 


00 0101 


5 


6 


06 


06 


00 


01 10 


00 OHIO 


6 


7 


07 


07 


00 


0111 


00 0111 


7 


8 


10 


08 


00 


1000 


00 1000 


8 


9 


11 


09 


00 


1001 


00 1001 


9 


# 


12 


OA 


00 


1010 


00 101 1 


8-3 


@ 


13 


OB 


00 


1011 


00 1100 


8-4 


? 


14 


OC 


00 


1100 


00 0000 


All other 
card codes 




15 


OD 


00 


1101 


00 1101 


8-5 


> 


16 


OE 


00 


1110 


00 1110 


8-6 


> 


17 


OF 


00 


mi 


00 1 1 1 1 


8-7 


+ 


20 


10 


01 


0000 


11 1010 


12 


A 


21 


11 


01 


0001 


11 0001 


12 1 


B 


22 


12 


01 


0010 


11 0010 


12 2 


C 


23 


13 


01 


0011 


11 0011 


12 3 


D 


24 


14 


01 


0100 


11 0100 


12 4 


E 


25 


15 


01 


0101 


11 0101 


12 5 


F 


26 


16 


01 


0110 


11 0110 


12 6 


G 


27 


17 


01 


0111 


11 0111 


12 7 



c 



E-5 



BCL COLLATING SEQUENCE (BCL INTERNAL) (Cont) 













BCL 






BCL 


BCL 


BCL 


BCL 


1 nternal 


External 


Card 


Code 


Character 


Octal 


Hex 


BA 


8421 


BA R421 


Zone 


Number 


H 


30 


18 


01 


1000 


11 1000 


12 


8 


1 


31 


19 


01 


1001 


11 1001 


12 


9 




32 


1A 


01 


1010 


11 1011 


12 


8-3 


i 


33 


IB 


01 


1011 


11 1100 


12 


8-4 


6 


34 


1C 


01 


1100 


1 1 0000 


12 


- 


( 


35 


ID 


01 


1101 


11 1101 


12 


8-5 


< 


36 


IE 


01 


1 110 


11 1110 


12 


8-6 


- 


37 


IF 


01 


mi 


11 11 1 1 


12 


8-7 


x(Mul t 


.Ho 


20 


10 


0000 


10 1010 







J 


41 


21 


10 


0001 


10 0001 




1 


K 


42 


22 


10 


0010 


10 0010 




2 


L 


43 


23 


10 


0011 


10 0011 




3 


M 


44 


24 


10 


0100 


10 0100 




4 


N 


45 


25 


10 


0101 


10 0101 




5 





46 


26 


10 


0110 


10 0110 




6 


P 


47 


27 


10 


0111 


10 0111 




7 


Q 


50 


28 


10 


1000 


10 1000 




8 


R 


51 


29 


10 


1001 


10 1001 




9 


S 


52 


2A 


10 


1010 


10 1011 




8-3 


>* 


53 


2B 


10 


101 1 


10 1 100 




8-4 


_ 


Sh 


2C 


10 


1100 


10 0000 




- 


) 


55 


2D 


10 


1101 


10 1101 




8-5 




56 


2E 


10 


1110 


10 1110 




8-6 


< 


57 


2F 


10 


mi 


io mi 




8-7 


Blank 


60 


30 


11 


0000 


01 0000 


- 


- 


/ 


61 


31 


1 1 


0001 


01 0001 





1 


S 


62 


32 


11 


0010 


01 0010 





2 


T 


63 


33 


11 


0011 


01 0011 





3 


U 


64 


34 


11 


0100 


01 0100 





4 


V 


65 


35 


1 1 


0101 


01 0101 





5 


w 


66 


36 


11 


0110 


01 0110 





6 


X 


67 


37 


11 


0111 


01 0111 





7 


Y 


70 


38 


11 


1000 


01 1000 





8 


Z 


71 


39 


11 


1001 


01 1001 





9 




72 


3A 


11 


1010 


01 1011 





8-3 


% 


73 


3B 


1 1 


1011 


01 1100 





8-4 


+ 


74 


3C 


11 


1100 


01 1010 





8-2 




75 


3D 


11 


1101 


01 1101 





8-5 


] 


76 


3E 


1 1 


1110 


01 1110 





8-6 




77 


3F 


11 


1111 


oi nn 


1° 


8-7 



31 



E-6 



COLLATING SEQUENCE - USASCII X3.4-1968 



USASCI I 


Hex 


1 nternal 


Character 


Code 


Code 








NUL 


00 


0000 0000 


SOH 


01 


0000 0001 


STX 


02 


0000 0010 


ETX 


03 


0000 0011 


EOT 


04 


0000 0100 


ENQ 


05 


0000 0101 


ACK 


06 


0000 0110 


BEL 


07 


ooob on i 


BS 


08 


0000 1000 


HT 


09 


0000 1001 


LF 


OA 


0000 1010 


VT 


OB 


0000 1011 


FF 


OC 


0000 1100 


CR 


00 


0000 1101 


SO 


OE 


0000 1110 


SI 


OF 


oooo mi 


DLE 


10 


0001 0000 


DCl 


11 


0001 0001 


DC2 


12 


0001 0010 


DC3 


13 


0001 0011 


DC4 


14 


0001 0100 


NAK 


15 


0001 0101 


SYN 


16 


0001 0110 


ETB 


17 


oooi oni 


CAN 


18 


0001 1000 


EM 


19 


0001 1001 


SUB 


1A 


0001 1010 


ESC 


IB 


oooi ion 


FS 


1C 


0001 1100 


GS 


ID 


0001 1101 


RS 


IE 


0001 1110 


US 


IF 


oooi mi 


SP 


20 


0010 0000 


| (or) 


21 


0010 0001 


II 


22 


0010 0010 


I 


23 


0010 0011 


$ 


24 


0010 0100 


% 


25 


0010 0101 


& 


26 


0010 0110 


/ 


27 


0010 0111 


( 


28 


0010 1000 


) 


29 


0010 1001 


* 


2A 


0010 1010 


+ 


2B 


0010 1011 


i 


2C 


0010 1100 



o 



USASCI 1 


Hex 


Internal 


Character 


Code 


Code 








- 


2D 


0010 1 101 


. 


2E 


0010 1110 


/ 


2F 


0010 1111 





30 


0011 0000 


1 


31 


0011 0001 


2 


32 


0011 0010 


3 


33 


0011 0011 


4 


34 


0011 0100 


5 


35 


0011 0101 


6 


36 


0011 0110 


7 


37 


0011 0111 


8 


38 


0011 1000 


9 


39 


0011 1001 


: 


3A 


0011 1010 


» 


3B 


0011 1011 


< 


3C 


0011 1100 


= 


3D 


0011 1101 


> 


3E 


0011 1110 


? 


3F 


oon nil 


§ 


40 


0100 0000 


A 


41 


0100 0001 


B 


42 


0100 0010 


C 


43 


0100 0011 


D 


44 


0100 0100 


E 


45 


0100 0101 


F 


46 


0100 0110 


G 


47 


0100 0111 


H 


48 


0100 1000 


1 


49 


oioo noi 


J 


4A 


0100 1010 


K 


4B 


oioo ion 


L 


4C 


0100 1 '00 


M 


4D 


0100 1101 


N 


4E 


0100 1110 





4F 


0100 1111 


P 


50 


0101 0000 


Q 


51 


0101 C001 


R 


52 


010-1 C010 


S 


53 


0101 0011 


T 


54 


0101 0100 


U 


55 


0101 0101 


V 


56 


0101 0110 


w 


57 


0101 0111 


X 


58 


0101 1000 



3 

o 

_l 

,1 



X 

o 



E-7 



COLLATING SEQUENCE - USASCII X3.4-1968 (Cont) 



USASCI I 


Hex 


Internal 


Character 


Code 


Code 








Y 


59 


0101 1001 


2 


5A 


0101 1010 


[ 


5B 


0101 1011 


\ 


5C 


0101 1100 


] 


5D 


0101 1101 


a(~i) 


5E 


0101 1100 


- 


5F 


0101 1111 


t 


60 


0110 0000 


a 


61 


0110 0001 


b 


62 


0110 0010 


c 


63 


0110 0011 


d 


64 


0110 0100 


c 


65 


0110 0101 


f 


66 


0110 0110 


9 


67 


ono on; 


h 


68 


0110 1000 


t 


69 


0110 100! 


J 


6A 


0110 1010 


k 


6B 


0110 1011 


1 


6C 


0110 1100 



o 



USASCI 1 


Hex 


Internal 


Character 


Code 


Code 








m 


60 


0110 1101 


n 


6E 


0110 1110 


o 


6F 


ono mi 


P 


70 


0111 0000 


q 


71 


0111 0001 


r 


72 


0111 0010 


s 


73 


0111 0011 


t 


7^ 


0111 0100 


u 


75 


0111 0101 


V 


76 


0111 ono 


w 


77 


0111 0111 


X 


78 


0111 1000 


y 


79 


0111 1001 


z 


7A 


0111 1010 


{ 


7B 


0111 1011 


1 
1 


7C 


0111 1100 


} 


7D 


0111 1101 


>v 


7E 


0111 1110 


DEL 


7F 


oiii mi 



o 

-J 



E-8 



COLLATING SEQUENCE - BCL TRANSLATED TO EBCDIC 



COLLATING SEQUENCE - BCL TRANSLATED TO EBCDIC 





BCL 






Translated 








BCL 


External 


BCL 


BCL 


EBCDIC 


EBCDIC 


Card 


Code 


Character 


BA 4321 


Hex. 


Octal 


Code 


Hex 


Zone 


Number 


(Blank) 


01 0000 


10 


20 


0100 0000 


40 


_ 




[ 


11 1100 


3C 


74 


0100 1010 


4A 


12 


8-4 


• 


11 1011 


3B 


73 


0100 1011 


4B 


12 


8-3 


< 


11 1110 


3E 


76 


0100 1)00 


4c 


12 


8-6 


( 


11 1101 


3D 


75 


0100 1101 


4D 


12 


8-5 


+ 


11 1010 


3A 


72 


0100 1110 


4e 


12 





■«- 


ii mi 


3F 


77 


oioo mi 


4F 


12 


8-7 


S 


11 0000 


30 


60 


0101 0000 


50 


12 


- 


] 


01 1110 


IE 


36 


0101 1010 


5A 





8-6 


$ 


10 1011 


2B 


53 


0101 1011 


5B 


11 


8-3 


* 


10 1100 


2C 


54 


0101 1100 


5C 


11 


8-4 


) 


10 1101 


2D 


55 


0101 1101 


5D 


11 


8-5 


> 


10 1110 


2E 


56 


0101 1110 


5E 


11 


8-6 


< 


io mi 


2F 


57 


oio) mi 


5F 


11 


8-7 


- 


10 0000 


20 


40 


0110 0000 


60 


11 


_ 


/ 


01 0001 


11 


21 


0110 0001 


61 





1 


t 


01 1011 


IB 


33 


0110 1011 


68 





8-3 


% 


01 1100 


1C 


3<» 


0110 1100 


6C 





8-4 


* 


01 1010 


1A 


32 


0110 1101 


6D 





8^2 


> 


00 1110 


0E 


16 


0110 1110 


6E 


- 


8-6 


? 


00 0000 


00 


00 


0110 1111 


6F 


All 
card 


other 
codes 




00 1101 


0D 


15 


0111 1010 


7A 


- 


8-5 


§ 


00 1011 


0B 


13 


0111 1011 


7B 


- 


8-3 


@ 


00 1100 


OC 


14 


0111 1100 


7C 


- 


8-4 


> 


00 1111 


OF 


17 


0111 1101 


7D 


- 


8-7 


s 


01 1101 


ID 


35 


0111 1110 


7E 





8-5 


1 1 


oi mi 


IF 


37 


oni mi 


7F 





8-7 


A 


11 0001 


31 


61 


1100 0001 


CI 


12 


1 


B 


11 0010 


32 


62 


1100 0010 


C2 


12 


2 


C 


11 0011 


33 


63 


1100 0011 


C3 


12 


3 


D 


11 0100 


34 


64 


1100 0100 


C4 


12 


4 


E 


11 0101 


35 


65 


1100 0101 


C5 


12 


5 


F 


11 0110 


36 


66 


1100 0110 


C6 


12 


6 


G 


1) 0111 


37 


67 


1100 0111 


C7 


12 


7 


H 


11 1000 


38 


70 


1100 1000 


C8 


12 


8 


1 


11 1001 


39 


71 


1100 1001 


C9 


12 


9 



o 



E-9 



COLLATING SEQUENCE - BCL TRANSLATED TO EBCDIC (Cont) 





BCL 






Translated 








BCL 


External 


BCL 


BCL 


EBCDIC 


EBCDIC 


Card 


Code 


Character 


BA 4321 


Hex. 


Octal 


Code 


Hex. 


Zone 


Number 


x(mult) 


10 1010 


2A 


52 


1101 0000 


DO 







J 


10 0001 


21 


41 


1101 0001 


Dl 




1 


K 


10 0010 


22 


42 


1101 0010 


D2 




2 


L 


10 0011 


23 


A3 


1101 0011 


03 




3 


M 


10 0100 


24 


44 


1101 0100 


D4 




4 


N 


10 0101 


25 


45 


1101 0101 


D5 




5 





10 0110 


26 


46 


1101 0110 


D6 




6 


P 


10 0111 


27 


47 


1101 0111 


D7 




7 


Q 


10 1000 


28 


50 


1101 1000 


D8 




8 


R 


10 1001 


29 


51 


1101 1001 


D9 




9 


S 


01 0010 


12 


22 


1110 0010 


E2 





2 


T 


01 0011 


13 


23 


1110 0011 


E3 





3 


U 


01 0100 


lit 


24 


1110 0100 


E4 





4 


V 


01 0101 


15 


25 


1110 0101 


E5 





5 


w 


01 0110 


16 


26 


1110 0110 


E6 





6 


X 


01 0111 


17 


27 


1110 0111 


E7 





7 


Y 


01 1000 


18 


30 


1110 1000 


E8 





8 


z 


01 1001 


19 


31 


1110 1001 


E9 





9 





00 1010 


0A 


12 


mi oooo 


FO 


- 





1 


00 0001 


01 


01 


mi oooi 


Fl 


- 


1 


2 


00 0010 


02 


02 


mi ooio 


F2 


- 


2 


3 


00 0011 


03 


03 


mi oon 


F3 


- 


3 


4 


00 0100 


04 


04 


nn oioo 


F4 


- 


4 


5 


00 0101 


05 


05 


1111 0101 


F5 


- 


5 


6 


00 0110 


06 


06 


.1111 0110 


F6 


- 


6 


7 


00 0111 


07 


07 


nn oin 


F7 


- 


7 


8 


00 1000 


08 


10 


nil looo 


F8 


- 


8 


9 


00 1001 


09 


11 


nn loot 


F9 


- 


9 



3 
O 



X 



E-10 



COLLATING SEQUENCE - BCL TRANSLATED TO USASCII 





BCL 






Trans lated 












BCL 


External 


BCL 


BCL 


USASCII 


USASCII 


Card 


Code 




Character 


BA 8*121 


Hex. 


Octal 


Code 


Hex. 


Zone 


Numbers 




Blank 


01 0000 


10 


20 


0010 0000 


20 


. 




3T 


■«- 


11 1111 


y 


77 


0010 0001 


21 


12 


8-7 


O 


it 


01 1111 


IF 


37 


0010 0010 


22 





8-7 




i 


# 


01 1011 


OB 


33 


0010 001 1 


23 


- 


8-3 






$ 


10 1011 


2B 


53 


0010 0100 


24 


11 


8-3 






t 


01 1100 


1C 


34 


0010 0101 


25 





8-4 






& 


11 0000 


30 


60 


0010 0110 


26 


12 


. 






> 


oi mi 


OF 


37 


0010 0111 


27 


- 


8-7 






( 


11 1101 


3D 


75 


0010 1000 


28 


12 


8-3 






) 


10 1101 


2D 


55 


0010 1001 


29 


11 


8-5 






* 


10 1100 


2C 


54 


0010 1010 


2A 


11 


8-4 






+ 


11 1010 


3A 


72 


0010 1011 


2B 


12 









• 


01 1011 


IB 


33 


0010 1100 


2C 





8-3 






- 


10 0000 


20 


4o 


0010 1101 


2D 


11 








• 


10 1011 


3B 


53 


0010 1110 


2E 


12 


8-3 






/ 


01 0001 


11 


21 


0010 1111 


2F 





1 









00 1010 


OA 


12 


0011 0000 


30 


_ 









1 


00 0001 


01 


01 


0011 0001 


31 


- 


1 






2 


00 0010 


02 


02 


0011 0010 


32 


- 


2 






3 


00 0011 


03 


03 


001 1 0011 


33 


- 


3 






k 


00 0100 


OA 


04 


0011 0100 


34 


- 


4 






5 


00 0101 


05 


05 


0011 0101 


35 


- 


5 






6 


00 0110 


06 


06 


0011 0110 


36 


- 


6 






7 


00 0111 


07 


07 


001 1 0111 


37 


- 


7 






tt 


00 1000 


08 


08 


0011 1000 


38 


- 


8 






4* 


00 1001 


09 


09 


0011 1001 


39 


- 


9 






: 


10 1101 


OD 


55 


0011 1010 


3A 


- 


8-5 






» 


10 1110 


2E 


56 


0011 1011 


3B 


11 


8-6 






< 


11 1110 


3E 


76 


0011 MOO 


3C 


12 


8-6 






m 


01 1101 


ID 


35 


0011 1101 


3D 





8-5 






> 


00 1110 


OE 


16 


0011 1110 


3E 


- 


8-6 






7 


00 0000 


00 


00 


oon mi 


3F 


All 
card 


other 
codes 






g 


00 1100 


OC 


14 


0100 0000 


40 


_ 


8-4 






A 


11 0001 


31 


61 


0100 0001 


41 


12 


1 






B 


11 0010 


32 


62 


0100 0010 


42 


12 


2 






C 


11 0011 


33 


63 


0100 001 1 


43 


12 


3 






D 


11 0100 


34 


64 


0100 0100 


44 


12 


4 






E 


11 0101 


35 


65 


0100 0101 


45 


12 


5 






F 


11 0110 


36 


66 


0100 01 10 


46 


12 


6 






G 


11 0111 


37 


67 


0100 01 1 1 


47 


12 


7 






H 


11 1000 


38 


70 


0100 1000 


48 


12 


8 






1 


11 1001 


39 


71 


0100 1001 


49 


12 


9 


1 


J 


10 0001 


21 


41 


0100 1010 


4A 


11 


1 


V 


K 


10 0010 


22 


42 


0100 101 1 


4B 


11 


2 


3r 


L 


10 0011 


23 


43 


0100 1100 


* 


11 


3 







E-11 



COLLATING SEQUENCE - BCL TRANSLATED TO USASCII (Cont) 





BCL 






Translated 










BCL 


External 


BCL 


BCL 


USASCII 


USASCI 1 


Card 


Code 




Character 


BA 8-t+2 1 


Hex. 


Octal 


Code 


Hex. 


Zone 


Number 




M 


10 0100 


2k 


kk 


0100 1101 


kD 


11 


k 


3: 
o 


N 


10 0101 


25 


k5 


0100 11 10 


kz 


11 


5 


—1 





10 0110 


26 


k(> 


0100 1111 


kF 


11 


6 


J, 


P 


10 0111 


27 


k7 


0101 0000 


50 


11 


7 




Q 


10 1000 


28 


50 


0101 0001 


51 


11 


8 




R 


10 1001 


29 


51 


0101 0010 


52 


1) 


9 




S 


01 0010 


12 


22 


0101 0011 


53 





2 




T 


01 0011 


13 


23 


0101 0100 


5k 





3 




U 


01 0100 


\k 


2k 


0101 0101 


55 





k 




V 


01 0101 


15 


25 


0101 0110 


56 





5 




w 


01 0110 


16 


26 


0101 0111 


57 





6 




X 


01 0111 


17 


27 


0101 1000 


58 





7 




Y 


01 1000 


18 


30 


0101 1001 


59 





8 




z 


01 1001 


19 


31 


0101 1010 


5A 





9 




I 


11 1100 


3C 


Ik 


0101 1011 


5B 


12 


8-4 




] 


01 1110 


IE 


36 


0101 1101 


50 





8-6 




< 


10 1111 


2F 


57 


0101 1110 


5E 


11 


8-7 


C3 


* 


01 1010 


1A 


32 


0101 1111 


5F 





8-2 


x(Mult) 


10 1010 


2A 


52 


0111 1101 


7D 


11 





; 



E-12 



COLLATING SEQUENCE 



US ASCII X3.4-1968 TRANSLATED TO 
EBCDIC 



LOW 



USASCI I 


USASC! I 


Translated 


EBCDIC 


USASC II 


USASCI I 


Translated 


EBCDIC 


Character 


Hex. Code 


EBCDIC Code 


Hex. Code 


Character 


Hex. Code 


EBCDIC Code 


Hex. Code 


NULL 


00 


0000 0000 


00 


& 


26 


0101 0000 


50 


SOH 


01 


0000 0001 


01 


] 


5D 


0101 1010 


5A 


STX 


02 


0000 0010 


02 


$ 


24 


0101 1011 


5B 


ETX 


03 


0000 0011 


03 


* 


2A 


0101 1100 


5C 


HT 


09 


0000 0101 


05 


) 


29 


0101 1101 


5D 


DEL 


7F 


0000 01 11 


07 


f 


3B 


0101 1110 


5E 


VT 


OB 


0000 1011 


OB 


A (— ") 


5E 


0101 1111 


5F 


FF 


OC 


0000 1100 


OC 










CR 


00 


0000 1101 


OD 


. 


2D 


0110 0000 


60 


SO 


OE 


0000 1110 


OE 


/ 


2F 


0110 0001 


61 


SI 


OF 


oooo mi 


OF 


1 


7C 


0110 1010 


6A 












2C 


0110 1011 


68 


OLE 


10 


0001 0000 


10 


% 


25 


0110 1100 


6C 


DC1 


11 


0001 0001 


11 




5F 


0110 1101 


6D 


DC 2 


12 


0001 0010 


12 


> 


3E 


0110 1110 


6E 


DC 3 


13 


0001 0011 


13 


? 


3F 


0110 11)1 


6F 


BS 


08 


0001 0110 


'« 
















\ 


60 


0111 1001 


79 










: 


3A 


0111 1010 


7A 










# 


23 


oin ion 


7B 


CAN 


18 


0001 1000 


18 


e 


4C 


0111 noo 


7C 


EM 


19 


0001 1001 


19 


* 


27 


0111 1101 


7D 


FS 


1C 


0001 1100 


1C 


m 


3D 


0111 1110 


7E 


GS 


ID 


0001 1101 


ID 


tl 


22 


oin mi 


7F 


RS 


IE 


0001 1110 


IE 










US 


IF 


oooi mi 


IF 


a 


61 


1000 0001 


81 










b 


62 


1000 0010 


82 


LF 


OA 


0010 0101 


25 


c 


63 


1000 0011 


83 


ETB 


17 


0010 0110 


26 


d 


64 


1000 0100 


84 


ESC 


IB 


0010 0111 


27 


e 


65 


1000 0101 


85 


ENQ 


05 


0010 1101 


2D 


f 


66 


1000 0110 


86 


ACK 


06 


0010 1110 


2E 


9 


67 


1000 01 11 


87 


BEL 


07 


0010 1111 


2F 


h 


65 


1000 1000 


88 










1 


65 


1000 1001 


89 


SYN 


16 


0011 0010 


32 










EOT 


04 


0011 0111 


37 


J 


6A 


1001 0001 


91 


DC) 


l<t 


0011 1100 


3C 


k 


6B 


1001 0010 


92 


NAK 


15 


0011 1101 


3D 


1 


6C 


1001 0011 


93 


SUB 


1A 


oon mi 


3F 


m 


6D 


1001 0100 


94 










n 


6E 


1001 0101 


95 


SP 


20 


0100 0000 


40 


o 


6F 


1001 0110 


96 


[ 


5B 


0100 1010 


4A 


p 


70 


1001 0111 


97 




2E 


0100 1011 


4B 


q 


71 


1001 1000 


98 


< 


3C 


0100 1100 


AC 


r 


72 


1001 1001 


99 


( 


28 


oioo noi 


4D 










+ 


26 


0100 1110 


4E 


<\, 


7D 


1010 0001 


Al 


| (or) 


21 


oioo mi 


4f 


s 


73 


1010 0010 


A2 



HIGH 



E-13 



COLLATING SEQUENCE - USASCII X3.4-1968 TRANSLATED TO 

EBCDIC (Cont) 



USASCII 


USASCII 


Trans lated 


EBCDIC 


Character 


Hex. Code 


EBCDIC Code 


Hex. Code 










t 


74 


1010 0011 


A3 


u 


75 


1010 0100 


A4 


V 


76 


1010 0101 


A5 


w 


77 


1010 0110 


A6 


X 


78 


1010 0111 


A7 


y 


79 


1010 1000 


A8 


z 


7A 


1010 1001 


A9 


{ 


7B 


1100 0000 


CO 


A 


ill 


1100 0001 


CI 


B 


42 


1100 0010 


C2 


C 


43 


1100 0011 


C3 


D 


44 


1100 0100 


C4 


E 


45 


1100 0101 


C5 


F 


46 


1100 0110 


C6 


G 


47 


1100 0111 


C7 


H 


48 


1100 1000 


C8 


I 


49 


1100 1000 


C9 


} 


70 


1101 0000 


DO 


J 


4A 


1101 0001 


Dl 


K 


4B 


1101 0010 


D2 


L 


4C 


1101 0011 


03 


M 


40 


1101 0100 


D4 


N 


4E 


1101 0101 


D5 





4F 


1101 0110 


D6 


P 


50 


1101 0111 


D7 


Q 


51 


1101 1000 


D8 


R 


52 


1101 1001 


09 


\ 


5C 


1110 0000 


E0 


S 


53 


1110 0010 


E2 


T 


54 


1110 0011 


E3 


U 


55 


1110 0100 


E4 


V 


56 


1110 0101 


E5 


w 


57 


1110 0110 


E6 


X 


58 


1110 0111 


E7 


Y 


59 


1110 1000 


E8 


Z 


5A 


1110 1001 


E9 





30 


1111 0000 


F0 


I 


13 


mi oooi 


Fl 


2 


32 


mi ooio 


F2 


3 


33 


mi ooii 


F2 


4 


34 


mi oioo 


F4 


5 


35 


nn oioi 


F5 


6 


36 


nn ouo 


F6 


7 


37 


1111 0111 


F7 


8 


38 


nn iooo 


F8 


9 


39 


1111 1001 


F9 



3 
o 



X 

o 



o 



X 

o 



E-14 



XALGOL COLLATING SEQUENCE (B 5700 BCL) 









BCL 


BCL 




BCL 


BCL 


BCL 


Internal External 


Card Code 


Character 


Octal 


Hex 


BA 8421 BA 8421 


Zone Number 


Blank 


60 


30 


1 1 0000 ( 


11 0000 


12 8-3 * 




32 


1A 


01 1010 


1 1011 


t 


33 


IB 


01 1011 1 


1 1100 


12 8-4 


( 


35 


ID 


01 1101 


1 1101 


12 8-5 


< 


36 


IE 


01 1110 


1 1110 


12 8-6 


■*■ 


37 


IF 


01 1111 


i mi 


12 8-7 


5c 


34 


1C 


01 1100 


1 0000 


12 - 


$ 


52 


2A 


10 1010 


1011 


" 8 -3 „, 


* 


53 


2B 


10 1011 


1100 


11 8-4 o 


) 


55 


2D 


10 1101 


1101 


11 8-5 5 


t 


56 


2E 


10 1110 


1110 


11 8-6 | 


< 


57 


2F 


10 1111 


o mi 


11 8-7 « 


- 


5* 


2C 


10 1100 


0000 


11 - g 


/ 


61 


31 


11 0001 ( 


)1 0001 


1 < 


> 


72 


3A 


11 1010 ( 


)1 1011 


8-3 g 


% 


73 


3B 


11 1011 ( 


)1 1100 


8-4 S 


m 


75 


3D 


11 1101 ( 


)1 1101 


8-5 


] 


76 


3E 


11 1110 ( 


)1 1110 


8-6 


II 


77 


3F 


ii mi 


)i nn 


8-7 


# 


12 


OA 


00 1010 


)0 1011 


- 8-3 


e 


13 


OB 


00 1011 


)0 1 1 00 


- 8-4 


: 


15 


OD 


00 1101 


)0 1101 


- 8-5 


> 


16 


OE 


00 1110 


)0 1110 


- 8-6 


> 


17 


OF 


00 1 1 1 1 


)0 1 11 1 


- 8-7 


+ 


20 


10 


01 0000 


11 1010 


12 g 


A 


21 


11 


01 0001 


11 0001 


12 1 2 


B 


22 


12 


01 0010 


11 0010 


12 2 


C 


23 


13 


01 0011 


11 0011 


12 3 





24 


14 


01 0100 


11 0100 


12 4 


E 


25 


15 


01 0101 


11 0101 


12 5 


F 


26 


16 


01 0110 


11 0110 


12 6 


G 


27 


17 


01 0111 


11 0111 


12 7 


H 


30 


18 


01 1000 


11 1000 


12 8 


1 


31 


19 


01 1001 


11 1001 


12 9 


X 


40 


20 


10 0000 


10 1010 


11 


J 


k] 


21 


10 0001 


10 0001 


11 1 


K 


42 


22 


10 0010 


10 0010 


11 2 


L 


43 


23 


10 0011 


10 0011 


11 3 


M 


44 


24 


10 0100 


10 0100 


11 4 


N 


45 


25 


10 0101 


10 0101 


11 5 



E-15 



XALGOL COLLATING SEQUENCE (B 5700 BCL) (Cont) 









BCL 


BCL 




BCL 


BCL 


BCL 


Internal 


External 


Card Code 


Character 


Octal 


Hex 


BA 8421 


BA 8421 


Zone Number 





46 


26 


10 0110 


10 0110 


11 6 


P 


47 


27 


10 0111 


10 0111 


11 7 g 


Q 


50 


28 


10 1000 


10 1000 


11 8 


R 


51 


29 


10 1001 


10 1001 


11 9 t 


* 


7^ 


3C 


11 1100 


01 1010 


8-2 


S 


62 


32 


11 0010 


01 0010 


2 


T 


63 


33 


11 0011 


01 0011 


3 


U 


64 


34 


11 0100 


01 0100 


4 


V 


65 


35 


11 0101 


01 0101 


5 


w 


66 


36 


11 0110 


01 0110 


6 


X 


67 


37 


11 0111 


01 0111 


7 


Y 


70 


38 


11 1000 


01 1000 


8 


z 


71 


39 


11 1001 


01 1001 


9 





00 


00 


00 0000 


00 1010 


- \ 


1 


01 


01 


00 0001 


00 0001 


- i 5 


2 


02 


02 


00 0010 


00 0010 


- 2 ^ 


3 


03 


03 


00 0011 


00 0011 


- 3 


4 


04 


04 


00 0100 


00 0100 


- 4 


5 


05 


05 


00 0101 


00 0101 


- 5 


6 


06 


06 


00 0110 


00 0110 


- 6 


7 


07 


07 


00 0111 


00 0111 


- 7 


8 


10 


08 


00 1000 


00 1000 


- 8 


9 


11 


09 


00 1001 


00 1001 


- 9 


? 


14 


OC 


00 1100 


00 0000 


ALL OTHER 
CARD CODES 



E-16 



FORTRAN BCD COLLATING SEQUENCE 



BCD 
Character 


Internal 


Representation 


Internal 


Translation 


Card 
Zone 


Code 
Number 


Hex 


Binary 


Binary 


Hex 


. (period) 


1A 


01 1010 


0100 1011 


4B 


12 


8-3 


) 


IB 


01 1011 


0100 1100 


4C 


12 


8-4 


+ 


1C 


01 1100 


0101 0000 


50 


12 




$ 


2A 


10 1010 


0101 1011 


5B 


11 


8-3 


* 


2B 


10 1011 


0101 1100 


5C 


11 


8-4 


S 


2E 


10 1110 


0101 1110 


5E 


11 


8-6 


< 


2F 


io mi 


oioi mi 


5F 


11 


8-7 


- (minus) 


2C 


10 1100 


0110 0000 


60 


11 




/ 


31 


11 0001 


0110 0001 


61 





1 


, (comma) 


3A 


M 1010 


0110 1011 


6B 





8-3 


( 


3B 


11 1011 


0110 1100 


6C 





8-4 


* 


3D 


11 1101 


0110 1101 


6D 





8-5 


> 


3E 


11 1110 


0110 1110 


6E 





8-6 


? 


3F 


11 1111 


0110 1111 


6F 





8-7 


m 


OA 


00 1010 


0111 1011 


7B 




8-3 


% 


9B 


00 1011 


0111 1100 


7C 




8-4 


i 


OD 


00 1101 


0111 1101 


70 




8-5 


m 


OE 


00 1110 


0111 1110 


7E 




8-6 


ii 


OF 


oo mi 


oin mi 


7F 




8-7 


A 


11 


01 0001 


1100 0001 


CI 


12 


1 


B 


12 


01 0010 


1100 0010 


C2 


12 


2 


C 


13 


01 0011 


1100 0011 


C3 


12 


3 


D 


14 


01 0100 


1100 0100 


C4 


12 


4 


E 


15 


01 0101 


1100 0101 


C5 


12 


5 


F 


16 


01 0110 


1100 0110 


C6 


12 


6 


8 


17 


01 0111 


1100 0111 


C7 


12 


7 


H 


18 


01 1000 


1100 1000 


C8 


12 


8 


1 


19 


01 1001 


1100 1001 


C9 


12 


9 


J 


21 


10 0001 


1101 0001 


Dl 


11 


1 


K 


22 


10 0010 


1101 0010 


D2 


11 


2 


L 


23 


10 0011 


1101 0011 


D3 


11 


3 


M 


24 


10 0100 


1101 0100 


D4 


11 


4 


N 


25 


10 0101 


1100 0101 


05 


11 


5 





26 


10 0110 


1101 0110 


D6 


11 


6 


P 


27 


10 0111 


not oin 


D7 


11 


7 


Q 


28 


10 1000 


1101 1000 


D8 


11 


8 


R 


29 


10 1001 


1101 1001 


D9 


11 


9 


S 


31 


11 0010 


1110 0010 


E2 





2 


T 


33 


11 0011 


1110 0011 


E3 





3 


U 


34 


11 0100 


1110 0100 


E4 





4 


V 


35 


11 0101 


1110 0101 


E5 





5 


w 


36 


11 0110 


1110 0110 


E6 





6 


X 


37 


11 0111 


1110 0111 


E7 





7 


Y 


38 


11 1000 


1110 1000 


E8 





8 


z 


39 


11 1001 


1110 1001 


E9 





9 





00 


00 0000 


mi oooo 


F0 







1 


01 


00 0001 


mi oooi 


Fl 




1 


2 


02 


00 0010 


mi ooio 


F2 




2 


3 


03 


00 001 1 


mi oon 


F3 




3 


it 


04 


00 0100 


mi oioo 


F4 




4 


5 


05 


05 0101 


nn oioi 


F5 




5 


6 


06 


00 0110 


mi ono 


F6 




6 


7 


07 


00 0111 


nn oin 


F7 




7 


8 


08 


00 1000 


nn iooo 


F8 




8 


9 


09 


00 1001 

'II — 


nn looi 


F9 




9 



E-17 



m 

i 
OB 



VTT 













O 


1 





1 








O 
t 




O 
1 


1 




1 
1 




1 
1 
1 


I 
O 







1 



i 






1 




i 


1 


1 
t 



l 

t 
1 


\'\v 


, 






\,\\. 




\- 






\ 


b 


b 
3 


b 

2 


i 







1 


2 


s 


4 


5 


8 


7 


4 


9 


10 


1 1 

(8) 


12 

<C) 


IS 

(0) 


14 

(E) 


15 

(F> 


* 

















NUL 
12-0-9-4-1 


DIE 

I2-II-9-9-I 


1 1-0-9-9-1 


I2-IMJ-4-4-I 


SP 

BLANK 


12 


II 


I2HI-0 


12-0-4-1 


12-1 1-4-1 


11-0-4-1 


12-11-0-4-1 


PZ(+) 

12-0 


HZ (!) 

tl-0 


\(CK)(t) 
0-4-2 






t 

» 











' 


■ 


SOH 

12-4-1 


DC1 
ll-9-t 


0-9-1 


9-i 


12-0- t-t 


12-11-9-1 


/ 

0-1 


I2-IMJ-9-I 


• 
12-0-1 


4 

12-tl-i 


ll-OH 


12-lt-OH 


A 
12-1 


J 
ll-l 


11-0-4-1 


1 
1 


» 








I 





2 


STX 
U-9-2 


0C2 
11-9-2 


0-9-2 


9-2 


12-0-9-2 


I2-IH9-2 


1 1-0-4-2 


I2-M-0-9-2 


12-0-2 


12-11-2 


11-0-2 


12-1 1-0-2 


4 
12-2 


K 

11-2 


S 
0-2 


2 

2 


3 








1 


' 


1 


12-9-9 


DCS 

11-9-1 


0-9- 3 


9- J 


12-0-9-3 


12-11-9-3 


1 
11-0-4-3 


12-11-0-9-3 


c 

12-0-3 


ll-ll-S 


ll-O-S 


12-1 KO-S 


C 

12-3 


L 
11.3 


T 
0-5 


3 
S 


i 





1 








4 


12-9-4 


11-9-4 


0-9-4 


9-4 


12-0-9-4 


12-1 1-9-4 


11-0-9-4 


I2-IH0-9-4 


4 
12-0-4 


M 

12-11-4 


11 0-4 


12-1 1-0-4 



12-4 


M 
1 1-4 


U 

0-4 


4 

4 


n 
■j 





I 





1 


S 


MT 
12-9-5 


NL 
1 1-9-9 


0-9-9 


9-9 


1 2-0-9-5 


12-1 1-9-5 


11-0-9-9 


12-1 1-0-9-9 


• 
12-0-9 


ft 

12-11-5 


i 
H-0-9 


12-11-0-5 


C 
12-S 


N 
11-9 


V 
0-9 


s 

5 


i 





1 


' 





• 


12-9-9 


■ S 
M-9-9 


ET4 
0-9-9 


»-« 


12-0-9-4 


I2HI-9-9 


1 1-0-4-4 


12-1 1-0-4-4 


r 

120-4 


« 
12-11-4 


11-0-4 


12-1 1-0 -4 


r 

12-4 



11-4 


W 
0-4 


4 
4 


> • 





1 


1 


1 


7 


DEL 

12-9-7 


II-9-T 


ESC 

0-9-7 


EOT 
9-7 


12-0-9-7 


I2HI-9-7 


11-0-9-7 


I2H 1-0-4-7 


t 

12-0-7 


9 
I2-M-7 


11-0-7 


12-1 1-0-7 



12-7 


P 
11-7 


X 
0-7 


7 
7 


>' +" 


' 











■ 


12-9-9 


CAN 
H-9-9 


0-9-9 


9-9 


120 9-9 


12-11-4-4 


110-4-4 


12 11-0-9-4 


h 
12- 0-4 


4 
12-11-4 


r 

H-0-9 


12-11-0-4 


H 
12-4 



11-9 


Y 
0.4 


8 

4 


> H 


I 








1 


4 


12-9-9-1 


EM 

11-9-9- 1 


0-9-9-1 


9-9-1 


12-9-1 


ll-B-l 


O-4-l 


4-1 


120-9 


12-11-9 


1 

11-0-9 


12-11-0-4 


1 
12-9 


R 
11-9 


Z 
0-9 


9 

9 


► — 

> 


I 





I 





10 u. 


12-9-9-2 


il-9-9-2 


0-9-9-2 


9-9-2 


C 
12-9-2 


3 

n-4-2 


12- II 


4-2 


120-9-2 


1211-9-2 


M-O-9-2 


12-11-0-4-2 


12-0-9-4-2 


12-11-9-4-2 


11*0-9-4-2 


I2-IM-9-9-2 




' 





1 


' 


" (.1 


VT 
1 1-9-9 5 


11-9-9-3 


0-9-9-3 


9-9-3 


t2-9-J 


S 

11-4-3 


0-4-3 


9-3 


12-0-9-1 


13-11-4-1 


110-9-3 


12 1 1-0-4-3 


12-0-9-4-3 


I2HI-9-4-3 


11-0-4-9-1 


1 2-1 K) -9-4-3 




I 


1 








12 

(C> 


FF 

12-9-9-4 


FS 

11-9-9-4 


0-9-9-4 


0C4 
9-9-4 


< 

12-9-4 


* 
11-4-4 


% 
0-4-4 


<? 

4-4 


12-0-4-4 


1 2-1 1-4-4 


11-0-4-4 


12-11-0-4-4 


12-0-4-4-4 


12-11-9-4-4 


11-0 4 4 4 


IMH344 4 




1 


1 





1 


rt .o, 


Cf* 
12 9-9-3 


69 
II 9-9-9 


ENQ 
0-9-9-8 


NAM 
9-9-9 


( 
12-9-5 


) 
11-4-5 


(USH*> 

0-4-5 


4-5 


12-0-4-5 


12-11-4-5 


11-0-4-5 


12-1 1-0-4-4 


120-9-9-5 


12-1 1-9-4-5 


11-0-9-4-9 


1 2-1 1-0-4-4-9; 




1 


1 


1 





■r (ii 


SO 

12-9-9-9 


BS 

11-9-9-9 


ACK 
9-9-9 


9-9-9 


12-4-9 


* 
11-4-4 


> 

0-4-6 


4-4 


12-0-4-4 


I2H-4-8 


11-0-4-4 


I2HI-0-4-4 


12-0-4-9-9 


I2-I1-4-4-4 


IIO-4-4-4 


I2-II-0-4-4-4 




t 


1 


1 


1 


IS 

<f> 


SI 
12-9- 9 -T 


US 
11-9-4-7 


BEL 
0-9-9-7 


SU9 
9-9-7 


It*-) " 
12-4-7 


11-4-7 


? 
0-4-7 


A* 
4-7 


120-4-7 


12-11-4-7 


II -0-4-7 


12-1 1-0-4-7 


OELIMCTEft 
12-0-9-9-T 


lt-1 1-9-4-7 


II -0-9-4-7 


12-4 1-0-4-4-7 



m 
x 

H 

m 

z 
o 
m 
o 

E 

z 
> 

< 

o 
o 

o 
m 

m° 

00 o 

o m 

2 o 

3 i 

> 



m 

33 

o 



O 
m 

o 
O 
o 
m 



APPENDIX F 



DATA REPRESENTATION 



EBCDIC 




DECIMAL 


EBCDIC 


HEX. 


EBCDIC 


BCL 




BCL 


BCL 


GRAPHIC 


BCL 


VALUE 


INTERNAL 


GRAPHIC 


CARD CODE 


CARD CODE 


OCTAL 


INTERNAL 


EXTERNAL 


BLANK 




64 


0100 0000 


40 


No Punches 


No Punches 


60 


11 0000 


01 0000 


[ 




74 


0100 1010 


4A 


12 8 2 


12 8 4 


33 


01 1011 


11 1100 






75 


0100 1011 


4B 


12 8 3 


12 8 3 


32 


01 1010 


11 1011 


< 




76 


0100 1100 


4C 


12 8 4 


12 8 6 


36 


01 1110 


11 1110 


( 




77 


0100 1101 


4D 


12 8 5 


12 8 5 


35 


01 1101 


11 1101 


+ 




78 


0100 1110 


4E 


12 8 6 








11 1010 


i 


«- 


79 


0100 1111 


4F 


12 8 7 


12 8 7 


37 


01 1111 


11 1111 


& 




80 


0101 0000 


50 


12 


12 


34 


01 1100 


11 0000 


] 




90 


0101 1010 


5A 


118 2 


8 6 


76 


11 1110 


01 1110 


$ 




91 


0101 1011 


5B 


118 3 


118 3 


52 


10 1010 


10 1011 


* 




92 


0101 1100 


5C 


118 4 


118 4 


53 


10 1011 


10 1100 


) 




93 


0101 1101 


5D 


118 5 


118 5 


55 


10 1101 


10 1101 






94 


0101 1110 


5E 


118 6 


118 6 


56 


10 1110 


10 1110 


— - 


< 


95 


0101 1111 


5F 


118 7 


118 7 


57 


10 1111 


10 1111 






96 


0110 0000 


60 


11 


11 


54 


10 1100 


10 0000 


/ 




97 


01100001 


61 


1 


1 


61 


1 1 0001 


01 0001 








1 07 


0110 1011 


6B 


8 3 


8 3 


72 


11 1010 


01 1011 


% 






I08 


0110 1100 


6C 


8 4 


8 4 


73 


11 1011 


01 1100 


— 


4 




1 09 


0110 1101 


6D 


8 5 


8 2 


74 


11 1100 


01 1010 


> 






no 


01101110 


6E 


8 6 


8 6 


16 


00 1110 


001110 


7 






in 


01101111 


6F 


8 7 


* 


14 


00 1100 


00 0000 








1 22 


0111 1010 


7A 


8 2 


8 5 


15 


00 1101 


00 1101 


# 






I23 


0111 1011 


7B 


8 3 


8 3 


12 


00 1010 


00 1011 


@ 






1 24 


0111 1100 


7C 


8 4 


8 4 


13 


00 1011 


00 1100 


' 


> 




1 25 


0111 1101 


7D 


8 5 


8 7 


17 


00 1111 


00 1111 


= 






1 26 


0111 1110 


7E 


8 6 


8 5 


75 


11 1101 


01 1101 


" 






1 27 


0111 1111 


7F 


8 7 


8 7 


77 


11 1111 


01 1111 


(+)PZ 


+ 




1 92 


1100 0000 


CO 


12 


12 


20 


01 0000 


11 1010 


A 






1 93 


1100 0001 


C1 


12 1 


12 1 


21 


010001 


11 0001 


B 






1 94 


1100 0010 


C2 


12 2 


12 2 


22 


01 0010 


11 0010 


C 






1 95 


1100 0011 


C3 


12 3 


12 3 


23 


01 0011 


11 0011 


D 






I96 


1100 0100 


C4 


12 4 


12 4 


24 


01 0100 


11 0100 


E 






1 97 


11000101 


C5 


12 5 


12 5 


25 


010101 


11 0101 


F 






I98 


11000110 


C6 


12 6 


12 6 


26 


01 0110 


11 0110 


G 






I99 


1100 0111 


C7 


12 7 


12 7 


27 


01 0111 


11 0111 


H 




:?oo 


1100 1000 


C8 


12 8 


12 8 


30 


01 1000 


11 1000 


1 




201 


1100 1001 


C9 


12 9 


12 9 


31 


01 1001 


11 1001 




MULT 


















<!)MZ 


X 


208 


1 101 0000 


DO 


11 


11 


40 


10 0000 


10 1010 


J 




209 


1101 0001 


D1 


11 1 


11 1 


41 


100001 


10 0001 


K 




210 


11010010 


D2 


11 2 


11 2 


42 


10 0010 


100010 


L 




211 


11010011 


D3 


11 3 


11 3 


43 


10 0011 


10 0011 


M 




212 


1101 0100 


D4 


11 4 


11 4 


44 


100100 


10 0100 


N 




213 


1101 0101 


D5 


11 5 


11 5 


45 


100101 


10 0101 







214 


1101 0110 


D6 


11 6 


11 6 


46 


100110 


10 0110 


P 






215 


11010111 


D7 


11 7 


11 7 


47 


100111 


10 0111 



*AII other codes 



F-1 



DATA REPRESENTATION 



EBCDIC 




DECIMAL 


EBCDIC 


HEX. 


EBCDIC 


BCL 




BCL 


BCL 


GRAPHIC 


BCL 


VALUE 


INTERNAL 


GRAPHIC 


CARD CODE 


CARD CODE 


OCTAL 


INTERNAL 


EXTERNAL 


Q 




216 


1101 1000 


D8 


11 8 


11 8 


50 


10 1000 


10 1000 


R 




217 


1101 1001 


D9 


11 9 


11 9 


51 


10 1001 


10 1001 


4 




224 


1110 0000 


EO 


8 2 








00 0000 


S 




226 


11100010 


E2 


2 


2 


62 


110010 


01 0010 


T 




227 


11100011 


E3 


3 


3 


63 


110011 


010011 


U 




228 


11100100 


E4 


4 


4 


64 


110100 


010100 


V 




229 


11100101 


E5 


5 


5 


65 


110101 


01 0101 


w 




230 


11100110 


E6 


6 


6 


66 


110110 


01 0110 


X 




231 


11100111 


E7 


7 


7 


67 


110111 


01 0111 


Y 




232 


1110 1000 


E8 


8 


8 


70 


11 1000 


01 1000 


z 




233 


1110 1001 


E9 


9 


9 


71 


11 1001 


01 1001 







240 


1111 0000 


FO 








00 


00 0000 


00 1010 


1 




241 


11110001 


F1 


1 


1 


01 


00 0001 


00 0001 


2 




242 


1111 0010 


F2 


2 


2 


02 


00 0010 


00 0010 


3 




243 


11110011 


F3 


3 


3 


03 


00 0011 


00 0011 


4 




244 


11110100 


F4 


4 


4 


04 


00 0100 


00 0100 


5 




245 


1111 0101 


F5 


5 


5 


05 


000101 


00 0101 


6 




246 


11110110 


F6 


6 


6 


06 


000110 


00 0110 


7 




247 


11110111 


F7 


7 


7 


07 


00 0111 


00 0111 


8 




248 


1111 1000 


F8 


8 


8 


10 


00 1000 


00 1000 


9 




249 


1111 1001 


F9 


9 


9 


11 


00 1001 


00 1001 



NOTES 

1. EBCDIC 0100 1110 also translates to BCL 11 1010. 

2. EBCDIC 1100 1111 is translated to BCL 00 0000 with an additional flag bit on the most 
significant bit line (8th bit). This function is used by the unbuffered printer to stop scanning. 

3. EBCDIC 1110 0000 is translated to BCL 00 0000 with an additional flag bit on the next 
to most significant bit line (7th bit). As the print drums have 64 graphics and space this signal 
can be used to print the 64th graphic. The 64th graphic is a "CR" for BCL drums and a u i" 
for EBCDIC drums. 

4. The remaining 189 EBCDIC codes are translated to BCL 00 0000 (? code). 

5. The EBCDIC graphics and BCL graphics are the same except as follows: 



BCL 

x (multiply) ! 
< _ 



EBCDIC 
(single quote) 



— ! (not) 
j (underscore) 



F-2 



APPENDIX G 

PROCESSOR OPERATORS, BY HEXADECIMAL 

CODE 



MODE IDA 


OPERATOR NAME 


MNEMONIC 


MODE ID & 


OPERATOR NAME h 


MNEMONIC 


HEX CODE 






HEX CODE 






(P)00-»3F 
(Z)00'->3F 
(P)40-*7F 
(Z)40-*7F 


VALUE CALL 
VECTOR FETCH 
NAME CALL 
VECTOR STORE 


VALC 

FETCH 

NAMC 

STOR 


(P)96 
(P)97 
(P)98 


BIT SET 

DYNAMIC BIT SET 
FIELD TRANSFER 


BSET 
DBST 
FLTR 


(V)42 


SET TWO SINGLES TO 
DOUBLE 


JOIN 


(P)99 


DYNAMIC FIELD 
TRANSFER 


DFTR 


(V)43 


SET DOUBLE TO TWO 


SPLT 


(P)9A 


FIELD ISOLATE 


ISOL 




SINGLES 




(P)9B 


DYNAMIC FIELD 


DISO 


(V)44 


IDLE UNTIL 


IDLE 




ISOLATE 






INTERRUPT 




(P)9C 


FIELD INSERT 


INSR 








(P)9D 


DYNAMIC FIELD 


DINS 


(V)46 


SET INTERVAL 


SINT 




INSERT 






TIMER 




(P)9E 


BIT RESET 


BRST 


(V)46 


ENABLE EXTERNAL 


EEXI 


(P)9F 


DYNAMIC BIT RESET 


DBRS 




INTERRUPTS 




(P)A0 


BRANCH FALSE 


BRFL 


(V)47 


DISABLE EXTERNAL 


DEXI 


(P)A1 


BRANCH TRUE 


BRTR 


(V)48 
(V)4A 


INTERRUPTS 
IGNORE PARITY 

SCAN IN 


IGPR 

SCNI 


(P)A2 


BRANCH 
UNCONDITIONAL 


BRUN 


(V)4E 


READ PROCESSOR 


WHOI 










IDENTIFICATION 




(P)A3 


EXIT 


EXIT 


(P)80 


ADD 


ADD 


(P)A4 


STEP AND BRANCH 


STBR 


(P)81 


SUBTRACT 


SUBT 


(P)A5 


INDEX AND LOAD 


NXLN 


(P)82 


MULTIPLY 


MULT 




NAME 




(P)83 


DIVIDE 


DIVD 


(F)A6 


INDEX 


INDX 


(P)84 


INTEGER DIVIDE 


IDV 


(P)A7 


RETURN 


RETN 


(V)84 


PAUSE UNTIL 
INTERRUPT 


PAUS 


(P)A8 


DYNAMIC BRANCH 
FALSE 


DBFL 


(P)86 


REMAINDER DIVIDE 


RDIV 


(V)A8 


SET MEMORY 


SINH 


(V)85 


OCCURS INDEX 


OCRX 




INHIBITS 




(P)86 


INTEGERIZE, 
TRUNCATED 


NTIA 


(P)A9 


DYNAMIC BRANCH 
TRUE 


DBTR 


(P)87 


INTEGERIZE, 
ROUNDED 


NTGR 


(P)AA 


DYNAMIC BRANCH 
UNCONDITIONAL 


DBUN 


(V)87 


INTEGERIZE, 


NTGD 


(V)AA 


SET MEMORY LIMITS 


SLMT 




ROUNDED, DOUBLE 




(P)AB 


ENTER 


ENTR 




PRECISION 




(P)AC 


EVALUATE 


EVAL 


(P)88 


LESS THAN 


LESS 




DESCRIPTOR 




(P)89 


GREATER. THAN OR 


GREQ 


(V)AC 


FETCH MEMORY FAIL 


FMFR 




EQUAL 




(P)AD 


INDEX AND LOAD 
VALUE 


NXLV 


(P)8A 


GREATER, THAN 


GRTR 


(P)AE 


MARK STACK 


MKST 


(P)8B 


LESS THAN OR 
EQUAL 


LSEQ 


(P)AF 


STUFF 
ENVIRONMENT 


STFF 


(V)8B 


LEADING ONE TEST 


LOG2 








(P) 


EQUAL 


EQUL 


(V)AF 


MOVE TO STACK 


MVST 


(P)8D 


NOT EQUAL 


NEQL 


(P)BO 


LIT CALL ZERO 


ZERO 


(P)8E 


CHANGE SIGN BIT 


CHSN 


(P)B1 


LIT CALL ONE 


ONE 








(P)B2 


LIT CALL 8 BITS 


LT8 


(P)8F 


EXTENDED 
MULTIPLE 


MULX 


(P)B3 


LIT CALL 16 BITS 


LT16 


(V)8F 


INTERRUPT 
CHANNEL N 


INCN 


(P)B4 


PUSH DOWN STACK 
REGISTERS 


PUSH 


(P)90 


LOGICAL AND 


LAND 


(V)B4 


SET TAG FIELD 


STAG 


(P)91 


LOGICAL OR 


LOR 


(P)B5 


DELETE TOP OF 


DLET 


(P)92 


LOGICAL NEGATE 


LNOT 




STACK 




(P)93 


LOGICAL 


LEQV 


(V)B5 


READ TAG FIELD 


RTAG 




EQUIVALENCE 




(P)B6 


EXCHANGE 


EXCH 


(P)94 


LOGICAL EQUAL 


SAME 


(V)B6 


ROTATE STACK UP 


RSUP 


(P)95 


ESCAPE TO 16-BIT 
INSTRUCTION 


VARI 


(P)B7 


DUPLICATE TOP OF 
STACK 


DUPL 
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MODE ID & 
HEX CODE 

(V)B7 
(P)B8 
(V)B8 

(P)B9 

(V)B9 

(P)BA 

(V)BA 
(P)BB 

(V)BB 
(V)BC 
(P)BD 
(V)BD 
(P)BE 

(V)BE 

(P)BF 

(V)BF 

(P)CO 

(P)C1 

(P)C2 

(P)C3 

(P)C4 
(P)C5 

(P)C6 
(P)C7 

(P)C8 
(P)C9 

(P)CA 

(P)CB 

(P)CC 



(P)CD 

(P)CE 

(P)CF 
(E)DO 
(P)DO 

(V)D0 

(E)D1 
(P)D1 
(V)D1 

(E)D2 



OPERATOR NAME 



MNEMONIC 



ROTATE STACK DOWN 


RSDN 


STORE DESTRUCTIVE 


STOD 


READ PROCESSOR 


RPRR 


REGISTER 




STORE NON- 


STON 


DESTRUCTIVE 




SET PROCESSOR 


SPRR 


REGISTER 




OVERWRITE 


OVRD 


DESTRUCTIVE 




READ WITH LOCK 


RDLK 


OVERWRITE NON- 


OVRN 


DESTRUCTIVE 




COUNT BINARY ONES 


CBON 


LOAD TRANSPARENT 


LODT 


LOAD 


LOAD 


LINKED LIST LOOKUP 


LLLU 


LIT CALL 48 BITS 


LT48 


MASKED SEARCH FOR 


SRCH 


EQUAL 




MAKE PROGRAM 


MPCW 


CONTROL WORD 




STOP 


STOP 


SCALE LEFT 


SCLF 


DYNAMIC SCALE 


DSLF 


LEFT 




SCALE RIGHT 


SCRT 


TRUNCATE 




DYNAMIC SCALE 


DSRT 


RIGHT TRUNCATE 




SCALE RIGHT SAVE 


SCRS 


DYNAMIC SCALE 


DSRS 


RIGHT SAVE 




SCALE RIGHT FINAL 


SCRF 


DYNAMIC SCALE 


DSRF 


RIGHT FINAL 




SCALE RIGHT ROUND 


SCRR 


DYNAMIC SCALE 


DSRR 


RIGHT ROUND 




INPUT CONVERT, 


ICVD 


DESTRUCTIVE 




INPUT CONVERT, 


ICVU 


UPDATE 




SET TO SINGLE 


SNGT 


PRECISION 




TRUNCATE 




SET TO SINGLE 


SNGL 


PRECISION, ROUNDED 




SET TO DOUBLE 


XTND 


PRECISION 




INSERT MARK STACK 


IMKS 


MOVE WITH INSERT 


MINS 


TABLE ENTER EDIT, 


TEED 


DESTRUCTIVE 




UNPACK SIGNED, 


USND 


DESTRUCTIVE 




MOVE WITH FLOAT 


MFLT 


PACK DESTRUCTIVE 


PACD 


UNPACK ABSOLUTE, 


UABD 



MODE ID & 


OPERATOR NAME 


MNEMONIC 


HEX CODE 






(P)D2 


EXECUTE SINGLE 
MICRO, DESTRUCTIVE 


EXSD 


(V)D2 


TRANSFER WHILE 
FALSE, DESTRUCTIVE 


TWFD 


(E)D3 


SKIP REVERSE 
SOURCE CHARACTERS 


SRSC 


(P)D3 


TRANSFER WORDS, 
DESTRUCTIVE 


TWSD 


(V)D3 


TRANSFER WHILE 
TRUE, DESTRUCTIVE 


TWTD 


(E)D4 


RESET FLOAT 


RSTF 


(P)D4 


TRANSFER WORDS, 


TWOD 



DESTRUCTIVE 
SKIP FORWARD 
SOURCE CHARACTERS 



SFSC 



(V)D4 

(E)D5 
(P)D5 

(V)D5 



(P)D6 
(E)D7 
(P)D7 

(V)D7 
(E)D8 
(P)D8 

(V)D8 

(E)D9 

(P)D9 
(V)D9 

(E)DA 

(P)DA 
(V)DA 

(E)DB 

(P)DB 
(V)DB 
(E)DC 
(P)DC 

(V)DC 

(E)DD 
(P)DD 

(V)DD 
(E)DE 



OVERWRITE 

DESTRUCTIVE 

SCAN WHILE FALSE, SWFD 

DESTRUCTIVE 

END FLOAT ENDF 

STRING ISOLATE SISO 

SCAN WHILE TRUE, SWTD 

DESTRUCTIVE 

(E)D6 MOVE NUMERIC MVNU 

UNCONDITIONAL 

SET EXTERNAL SIGN SXSN 

MOVE CHARACTERS MCHR 

READ AND CLEAR ROFF 

OVERFLOW FLIP-FLOP 

TRANSLATE TRNS 

INSERT OVERPUNCH INOP 

TABLE ENTER EDIT, TEEU 

UPDATE 

UNPACK SIGNED USNU 

UPDATE 

INSERT DISPLAY INSG 

SIGN 

PACK UPDATE PACU 

UNPACK ABSOLUTE, UABU 

UPDATE 

SKIP FORWARD SFDC 

DESTINATION 

CHARACTERS 

EXECUTE SINGLE EXSU 

MICRO, UPDATE 

TRANSFER WHILE TWFU 

FALSE, UPDATE 

SKIP REVERSE SRDC 

DESTINATION 

CHARACTERS 

TRANSFER WORDS, TWSU 

UPDATE 

TRANSFER WHILE TWTU 

TRUE, UPDATE 

INSERT INSU 

UNCONDITIONAL 

TRANSFER WORDS TWOU 

OVERWRITE UPDATE 

SCAN WHILE FALSE, SWFU 

UPDATE 

INSERT CONDITIONAL INSC 

EXECUTE SINGLE EXPU 

MICRO, SINGLE 

POINTER UPDATE 

SCAN WHILE TRUE, SWTU 

UPDATE 

END EDIT ENDE 
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MODE ID & 


OPERATOR NAME 


MNEMONIC 


MODE ID & 


OPERATOR NAME h 


MNEMONIC 


HEX CODE 






HEX CODE 






(P)DE 


READ TRUE/FALSE 
FLIP-FLOP 


RTFF 


(V)F0 


SCAN WHILE LESS, 
DESTRUCTIVE 


SLSD 


(E)DF 


CONDITIONAL HALT 


HALT 


(Z)FO 


STORE A 


STA 


(P)DF 


CONDITIONAL HALT 


HALT 


(P)F1 


COMPARE 


CGED 


(V)DF 


CONDITIONAL HALT 


HALT 




CHARACTERS 




(P)E0 


TRANSFER WHILE 
LESS, DESTRUCTIVE 


TLSD 




GREATER OR EQUAL, 
DESTRUCTIVE 




(Z)E0 
(P)E1 


LOAD A 

TRANSFER WHILE 
GREATER OR EQUAL, 
DESTRUCTIVE 


LDA 
TGED 


(V)F1 


SCAN WHILE 
GREATER OR EQUAL, 
DESTRUCTIVE 


SGED 


(Z)E1 
(P)E2 


LOAD A INCREMENT 
TRANSFER WHILE 
GREATER, 
DESTRUCTIVE 


LDAI 
TGTD 


(Z)F1 
(P)F2 


STORE A INCREMENT 
COMPARE 
CHARACTERS 
GREATER, 


STAI 
CGTD 


(Z)E2 


LOAD B 


LDB 


(V)F2 


DESTRUCTIVE 
SCAN WHILE 


SGTD 


(P)E3 


TRANSFER WHILE 
LESS OR EQUAL, 


TLED 




GREATER, 
DESTRUCTIVE 






DESTRUCTIVE 




(Z)F2 


STORE B 


STB 


(Z)E3 
(P)E4 

(Z)E4 
(P)E5 

(Z)E5 
(P)E6 


LOAD B INCREMENT 
TRANSFER WHILE 
EQUAL, DESTRUCTIVE 
LOAD C 

TRANSFER WHILE 
NOT EQUAL, 
DESTRUCTIVE 
LOAD C INCREMENT 
TRANSFER 
UNCONDITIONAL, 
DESTRUCTIVE 


LDBI 
TEQD 

LDC 
TNED 

LDCI 
TUND 


(P)F3 

(V)F3 

(Z)F3 
(P)F4 


COMPARE 
CHARACTERS LESS 
OR EQUAL, 
DESTRUCTIVE 
SCAN WHILE LESS OR 
EQUAL, DESTRUCTIVE 
STORE B INCREMENT 
COMPARE 

CHARACTERS EQUAL, 
DESTRUCTIVE 


CLED 

SLED 

STB I 
CEQD 


(Z)E6 
(P)E7 


VECTOR EXIT 
MULTIPLE-WORD 


VXIT 
VMOM 


(V)F4 


SCAN WHILE EQUAL, 
DESTRUCTIVE 


SEQD 




VECTOR MODE 




(Z)F4 


STORE C 


STC 


(Z)E7 


MULTIPLE-WORD 
VECTOR MODE 


VMOM 


(P)F5 


COMPARE 
CHARACTERS NOT 


CNED 


(P)E8 


TRANSFER WHILE 


TLSU 




EQUAL, DESTRUCTIVE 






LESS, UPDATE 




(V>F5 


SCAN WHILE NOT 


SNED 


(Z)E8 


DOUBLE LOAD A 


DLA 




EQUAL, DESTRUCTIVE 




(P)E9 


TRANSFER WHILE 


TGEU 


(Z)F5 


STORE C INCREMENT 


STCI 




GREATER OR EQUAL, 




(P)F8 


COMPARE 


CLSU 




UPDATE 






CHARACTERS LESS, 




(Z)E9 


DOUBLE LOAD A 


DLAI 




UPDATE 




(P)EA 


INCREMENT 
TRANSFER WHILE 


TGTU 


(V1F8 


SCAN WHILE LESS, 

UPDATE 

DOUBLE STORE A 

COMPARE 

CHARACTERS 

GREATER OR EQUAL, 

UPDATE 

SCAN WHILE 

GREATER OR EQUAL, 

UPDATE 


SLSU 


(Z)EA 
(P)EB 

(Z)EB 
(P)EC 


GREATER, UPDATE 
DOUBLE LOAD B 
TRANSFER WHILE 
LESS OR EQUAL, 
UPDATE 

DOUBLE LOAD B 
INCREMENT 
TRANSFER WHILE 


DLB 
TLEU 

DLBI 
TEQU 


(Z)F8 
(P)F9 

O0F9 


DSA 
CGEU 

SGEU 


(P)ED 


EQUAL, UPDATE 
TRANSFER WHILE 
NOT EQUAL, UPDATE 


TNEU 


(Z)F9 


DOUBLE STORE A 
INCREMENT 


DSAI 


(Z)ED 


DOUBLE LOAD C 
INCREMENT 


DLCI 


(P)FA 


COMPARE 
CHARACTERS 


CGTU 


(P)EE 


TRANSFER 


TUNU 




GREATER, UPDATE 






UNCONDITIONAL, 




(V)FA 


SCAN WHILE 


SGTU 




UPDATE 






GREATER, UPDATE 




(Z)EE 


VECTOR BRANCH 


VEBR 


(Z)FA 


DOUBLE STORE B 


DSB 


(P)EF 


SINGLE-WORD 
VECTOR MODE 


VMOS 


(P)FB 


COMPARE 
CHARACTERS LESS 


CLEU 


(Z)EF 
(P)F0 


SINGLE-WORD 
VECTOR MODE 
COMPARE 


VMOS 
CLSD 


(V)FB 


OR EQUAL, UPDATE 
SCAN WHILE LESS OR 
EQUAL, UPDATE 


SLEU 




CHARACTERS LESS, 




(Z)FB 


DOUBLE STORE B 


DSBI 




DESTRUCTIVE 






INCREMENT 
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MODE ID & 
HEX CODE 


OPERATOR NAME 


MNEMONIC 


MODE ID & 
HEX CODE 


OPERATOR NAME 


(P)FC 




COMPARE 

CHARACTERS EQUAL, 
UPDATE 


CEQU 


(Z)FD 
(E)FE 




DOUBLE STORE C 
INCREMENT 

NO OPERATION 


(V)FC 




SCAN WHILE EQUAL, 
UPDATE 


SEQU 


(P)FE 
(V)FE 




NO OPERATION 
NO OPERATION 


(Z)FC 




DOUBLE STORE C 


DSC 


(Z)FE 




NO OPERATION 


(P)FD 




COMPARE 
CHARACTERS NOT 
EQUAL, UPDATE 


CNEU 


(E)FF 
(P)FF 




INVALID OPERATION 
INVALID OPERATION 


(V)FD 




SCAN WHILE NOT 
EQUAL. UPDATE 


SNEU 


(V)FF 
(Z)FF 




INVALID OPERATION 
INVALID OPERATION 



MNEMONIC 



DSCI 



NOOP 
NOOP 
NOOP 

NOOP 



NVLD 
NVLD 
NVLD 
NVLD 
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APPENDIX H 
PROCESSOR OPERATORS BY MNEMONICS 



MNEMONIC 


: MODE ID ft 
HEX CODE 


OPERATOR 
NAME 


PAGE 


MNEMONIC 


MODE ID 


ft OPERATOR 


PAGE 


ADD 


(P)80 


ADD 


3-69 




HEX CODE NAME 


BRFL 

BRST 


(P)AO 
(P)9E 


BRANCH ON 
FALSE 
BIT RESET 


3-70 

3-70 


DBST 
DBTR 


(P)97 
(P)A9 


DYNAMIC BIT 

SET 

DYNAMIC 


3-70 
3-71 


BRTR 


(P)A1 


BRANCH ON 


3-70 






BRANCH TRUE 




BRUN 


(P)A2 


TRUE 

BRANCH 

UNCONDITIONAL 


3-70 


DBUN 


(P)AA 


DYNAMIC 

BRANCH 

UNCONDITIONAL 


3-70 


BSET 
CBON 


(P)96 
(V)BB 


BIT SET 
COUNT 
BINARY ONES 


3-70 
3-70 


DEXI 


(V)47 


DISABLE 

EXTERNAL 

INTERRUPTS 


3-98 


CEQD 


(P)F4 


COMPARE 

CHARACTERS 

EQUAL, 


3-72 


DFTR 


(P)99 


DYNAMIC 

FIELD 

TRANSFER 


3-88 






DESTRUCTIVE 




DINS 


(P)9D 


DYNAMIC 


3-96 


CEQU 


(P)FC 


COMPARE 


3-72 






FIELD INSERT 








CHARACTERS 




DISO 


(P)9B 


DYNAMIC 


3-88 






EQUAL, 








FIELD 




CGED 


(P)F1 


UPDATE 
COMPARE 


3-72 






ISOLATE 








CHARACTERS 




DIVD 


(P)83 


DIVIDE 


3-69 






GREATER OR 




DLA 


(Z)E8 


DOUBLE LOAD 


3-105 






EQUAL, 








A 








DESTRUCTIVE 




DLAI 


(Z)E9 


DOUBLE LOAD 


3-105 


CGEU 


(P)F9 


COMPARE 


3-72 






A INCREMENT 








CHARACTERS 




DLB 


(Z)EA 


DOUBLE LOAD 


3-105 






GREATER OR 








B 








EQUAL, 




DLBI 


EB 


DOUBLE LOAD 


3-105 






UPDATE 








B INCREMENT 




CGTD 


(P)F2 


COMPARE 
CHARACTERS 


3-72 


DLC 


(Z)EC 


DOUBLE LOAD 
C 


3-105 






GREATER, 




DLCI 


(Z)ED 


DOUBLE LOAD 


3-105 






DESTRUCTIVE 








C INCREMENT 




CGTU 


(P)FA 


COMPARE 


3-71 














CHARACTERS 




DLET 


(P)B5 


DELETE TOP 


3-81 






GREATER, 








OF STACK 








UPDATE 




DSA 


(Z)F8 


DOUBLE 


3-105 


CHSN 


(P)8E 


CHANGE SIGN 


3-70 






STORE A 








BIT 




DSAI 


(Z)F9 


DOUBLE 


3-106 


CLED 


(P)F3 


COMPARE 
CHARACTERS 


3-72 






STORE A 
INCREMENT 








LESS OR 




DSB 


(Z)FA 


DOUBLE 


3-106 






EQUAL, 
DESTRUCTIVE 




DSBI 


(Z)FB 


STORE B 
DOUBLE 


3-106 


CLEU 


(P)FB 


COMPARE 


3-72 






STORE B 








CHARACTERS 
LESS OR 




DSC 


(Z)FC 


increment 
Double 


3-106 






EQUAL, 
UPDATE 




DSCI 


(Z)FD 


STORE C 
DOUBLE 


3-106 


CLSD 


(P)F0 


COMPARE 
CHARACTERS 


3-72 






STORE C 
INCREMENT 








l:ess, 




DSLF 


(P)C1 


DYNAMIC 


3-80 






DESTRUCTIVE 








SCALE LEFT 




CLSU 


(P)F8 


COMPARE 
CHARACTERS 
LESS, UPDATE 


3-72 


DSRF 


(P)C7 


DYNAMIC 
SCALE RIGHT 
FINAL 


3-80 


CNEU 


(P)FD 


COMPARE 
CHARACTERS 
NOT EQUAL, 


3-72 


DSRR 


(P)C9 


DYNAMIC 
SCALE RIGHT 
ROUNDED 


3-80 






UPDATE 




DSRS 


(P)C5 


DYNAMIC 


3-80 


DBFL 


(P)A8 


DYNAMIC 
BRANCH 


3-71 






SCALE RIGHT 
SAVE 








FALSE 




DSRT 


(P)C3 


DYNAMIC 


3-80 


DBRS 


(P)9F 


DYNAMIC BIT 

RESET 


3-70 






SCALE RIGHT 
TRUNCATE 
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MNEMONIC 


: MODE ID & 
HEX CODE 


OPERATOR 
NAME 


PAGE 


MNEMONIC 


MODE ID & OPERATOR 
HEX CODE NAME 


PAGE 


DUPL 

EEXI 

ENDE 
ENDF 


(P)B7 
(V)46 

(E)DE 
(E)D5 


DUPLICATE 
TOP OF STACK 
ENABLE 
EXTERNAL 
INTERRUPTS 
END EDIT 
END FLOAT 


3-81 
3-98 

3-104 
3-103 


INSC 

INSG 

INSR 
INSU 

ISOL 


(E)DD 

(E)D9 

(P)9C 
(E)DC 

(P)9A 


INSERT 
CONDITIONAL 
INSERT 
DISPLAY SIGN 
FIELD INSERT 
INSERT 

UNCONDITIONAL 
FIELD 


3-102 

3-102 

3-96 
3-102 

3-88 


ENTR 


(P)AB 


ENTER 


3-88 






ISOLATE 


3-96 


EQUL 


(P)8C 


EQUAL 


3-79 


JOIN 


(V)42 


SET TWO 


EVAL 


(P)AC 


EVALUATE 
DESCRIPTOR 


3-85 






SINGLES TO 
DOUBLE 




EXCH 


(P)B6 


EXCHANGE 


3-80 


LAND 


(P)90 


LOGICAL AND 


3-78 


EXIT 




(P)A3 EXIT 


3-88 


LDA 


(Z)E0 


LOAD A 


3-105 


EXPU 


(P)DD 


EXECUTE 
SINGLE 


3-73 


LDAI 


(Z)E1 


LOAD A 
INCREMENT 


3-105 






MICRO, 




LDB 


(Z)E2 


LOAD B 


3-105 






SINGLE 




LDBI 


(Z)E3 


LOAD B 


3-105 






POINTER 








INCREMENT 








UPDATE 




LDC 


(Z)E4 


LOAD C 


3-105 


EXSD 


(P)D2 


EXECUTE 
SINGLE 


3-73 


LDCI 


(Z)E5 


LOAD C 
INCREMENT 


3-105 






MICRO, 




LEQV 


(P)93 


LOGICAL 


3-78 






DESTRUCTIVE 








EQUIVALENCE 




EXSU 


(P)DA 


EXECUTE 


3-73 


LESS 


(P)88 


LESS THAN 


3-79 






SINGLE 




LLLU 


(V)BD 


LINKED LIST 


3-100 






MICRO, 








LOCKUP 








UPDATE 




LNOT 


(P)92 


LOGICAL 
NEGATE 


3-78 


FLTR 


(P)98 


FIELD 


3-88 


LOAD 


(P)BD 


LOAD 


3-77 






TRANSFER 




LODT 


(V)BC 


LOAD 


3-77 


FMFR 


(V)AC 


FETCH 


3-101 






TRANSPARENT 








MEMORY FAIL 




LOG2 


(V)8B 


LEADING ONE 


3-70 






REGISTER 








TEST 




FTCH 


(Z)00->3F 


VECTOR 


3-106 


LOR 


(P)91 


LOGICAL OR 


3-78 






FETCH 




LSEQ 


(P)8B 


LESS THAN OR 


3-79 


GREQ 


(P)89 


GREATER 


3-79 






EQUAL 








THAN OR 




LT16 


(P)B3 


LIT CALL 16 


3-78 






EQUAL 








BITS 




GRTR 


(P)8A 


GREATER 
THAN 


3-79 


LT48 


(P)BE 


LIT CALL 48 
BITS 


3-78 


HALT 


(DDF 


CONDITIONAL 
HALT 


3-96 


LT8 


(P)B2 


LIT CALL 8 
BITS 


3-78 


HALT 


(V)DF 


CONDITIONAL 
HALT 


3-96 


MCHR 


(E)D7 


MOVE 
CHARACTERS 


3-103 


HALT 


(E)DF 


CONDITIONAL 
HALT 


3-96 


MFLT 


(E)D1 


MOVE WITH 

FLOAT 


3-103 


ICVD 


(P)CA 


INPUT 
CONVERT, 


3-77 


MINS 


(E)D0 


MOVE WITH 
INSERT 


3-102 






DESTRUCTIVE 




MKST 


(P)AE 


MARK STACK 


3-85 


ICVU 


(P)CB 


INPUT 

CONVERT, 

UPDATE 


3-77 


MPCW 


(P)BF 


MAKE 

PROGRAM 

CONTROL 


3-78 


IDIV 


(P)84 


INTEGER 


3-69 






WORD 








DIVIDE 




MULT 


(P)82 


MULTIPLY 


3-69 


IDLE 


(V)44 


IDLE UNTIL 
INTERRUPT 


3-98 


MULX 


(P)8F 


EXTENDED 
MULTIPLY 


3-69 


IGPR 


(V)48 


IGNORE 
PARITY 


3-101 


MVNU 


(E)D6 


MOVE 
NUMERIC 


3-103 


IMKS 


(P)CF 


INSERT MARK 


3-85 






UNCONDITIONAL 








STACK 




MVST 


(V)AF 


MOVE TO 


3-100 


INCN 


(V)8F 


INTERRUPT 


3-102 






STACK 








CHANNEL N 




SFDC 


(E)DA 


SKIP 


3-103 


INDX 


(P)A6 


INDEX 


3-76 






FORWARD 




INOP 


(E)D8 


INSERT 
OVERPUNCH 


3-102 






DESTINATION 
CHARACTERS 
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MNEMONIC 

SFSC 

SGED 

SGEU 

SGTD 

SGTU 

SINH 
SINT 
SISO 
SLED 

SLEU 

SLMT 
SLSD 

SLSU 
SNED 



SNGT 



SPLT 



SPRR 



MODE ID & 
HEX CODE 

(E)D2 



(V)F1 

(V)F9 

(V)F2 

(V)FA 

(V)A8 
(V)45 
(P)D5 
(V)F3 

(V)FB 

(V)AA 
(V)F0 

(V)F8 
(V)F5 



SNEU (V)FD 



SNGL (P)CD 



(P)CC 



(V)43 



(V)B9 



SRCH (V)BE 



SRDC (E)DB 



SRSC (E)D3 



OPERATOR 
NAME 

SKIP 

FORWARD 

SOURCE 

CHARACTERS 

SCAN WHILE 

GREATER OR 

EQUAL, 

DESTRUCTIVE 

SCAN WHILE 

GREATER OR 

EQUAL, 

UPDATE 

SCAN WHILE 

GREATER, 

DESTRUCTIVE 

SCAN WHILE 

GREATER, 

UPDATE 

SET MEMORY 

INHIBITS 

SET INTERVAL 

TIMER 

STRING 

ISOLATE 

SCAN WHILE 

LESS OR 

EQUAL, 

DESTRUCTIVE 

SCAN WHILE 

LESS OR 

EQUAL, 

UPDATE 

SET MEMORY 

LIMITS 

SCAN WHILE 

LESS, 

DESTRUCTIVE 

SCAN WHILE 

LESS, UPDATE 

SCAN WHILE 

NOT EQUAL, 

DESTRUCTIVE 

SCAN WHILE 

NOT EQUAL, 

UPDATE 

SET TO 

SINGLE 

PRECISION, 

ROUNDED 

SET TO 

SINGLE 

PRECISION, 

TRUNCATED 

SET DOUBLE 

TO TWO 

SINGLES 

SET 

PROCESSOR 

REGISTER 

MASKED 

SEARCH FOR 

EQUAL 

SKIP REVERSE 

DESTINATION 

CHARACTERS 

SKIP REVERSE 

SOURCE 

CHARACTER 



PAGE 


MNEMONIC 


MODE ID & 


OPERATOR 






HEX CODE 


NAME 


3-103 


STA 


(Z)F0 


STORE A 




STAG 


(V)B4 


SET TAG 
FIELD 




STAI 


(Z)F1 


STORE A 


3-97 






INCREMENT 




STB 


(Z)F2 


STORE B 




STB I 


(Z)F3 


STORE B 
INCREMENT 


3-97 


STBR 


(P)A4 


STEP AND 
BRANCH 




STC 


(Z)F4 


STORE C 




STCI 


(Z)F5 


STORE C 


3-97 






INCREMENT 




STFF 


(P)AF 


STUFF 
ENVIRONMENT 


3-97 


STOD 


(P)B8 


STORE 
DESTRUCTIVE 




STON 


(P)B9 


STORE NON- 


3-101 






DESTRUCTIVE 




STOP 


(V)BF 


STOP 


3-98 


STOR 


(Z)40— *7F 


VECTOR STORE 




SUBT 


(P)81 


SUBTRACT 


3-82 


SWFD 


(V)D4 


SCAN WHILE 






FALSE, 


3-97 






DESTRUCTIVE 


3-97 


SWFU 


(V)DC 


SCAN WHILE 

FALSE, 

UPDATE 




SWTD 


(V)D5 


SCAN WHILE 


3-101 






TRUE, 
DESTRUCTIVE 


3-97 


SWTU 


(V)DD 


SCAN WHILE 
TRUE, UPDATE 




SXSN 


(P)D6 


SET 


397 






EXTERNAL 
SIGN 


3-97 


TEED 


(P)D0 


TABLE ENTER 

EDIT, 

DESTRUCTIVE 


3-98 


TEEU 


(P)D8 


TABLE ENTER 
EDIT, UPDATE 




TEQD 


(P)E4 


TRANSFER 


3-96 






WHILE EQUAL, 
DESTRUCTIVE 




TEQU 


(P)EC 


TRANSFER 
WHILE EQUAL, 


3-96 






UPDATE 




TGED 


(P)E1 


TRANSFER 
WHILE 
GREATER OR 


3-96 






EQUAL, 
DESTRUCTIVE 




TGEU 


(P)E9 


TRANSFER 


3-99 






WHILE 
GREATER OR 
EQUAL, 


3-100 






UPDATE 




TGTD 


(P)E2 


TRANSFER 
WHILE 


3-103 






GREATER, 
DESTRUCTIVE 




TGTU 


(P)EA 


TRANSFER 


3-103 






WHILE 

GREATER, 

UPDATE 



PAGE 

3-105 
3-98 

3-105 

3-105 
3-105 

3-71 

3-105 
3-105 

3-96 

3-81 

3-81 

3-102 

3-106 

3-69 

3-98 



3-98 

3-98 

3-98 
3-96 

3-73 

3-73 
3-83 

3-83 
3-83 

3-83 

3-83 
3-83 

H-3 



APPENDIX H (Cont) 



INEMONK 


: MODE ID & 


OPERATOR 


PAGE 


MNEMONIC 


MODE ID & 


OPERATOR 


PAGE 




HEX CODE 


NAME 




HEX CODE 


NAME 




TLED 


(P)E3 


TRANSFER 
WHILE LESS 
OR EQUAL, 


3-83 


TWSU 


(P)DB 


TRANSFER 

WORDS, 

UPDATE 


3-82 






DESTRUCTIVE 




TWTD 


(V)D3 


TRANSFER 


3-84 


TLEU 


(P)EB 


TRANSFER 
WHILE LESS 


3-83 






WHILE TRUE, 
DESTRUCTIVE 








OR EQUAL, 




TWTU 


(V)DB 


TRANSFER 


3-84 






UPDATE 








WHILE TRUE, 




TLSD 


(P)EO 


TRANSFER 


3-83 






UPDATE 








WHILE LESS, 




UABD 


(V)D1 


UNPACK 


3-99 






DESTRUCTIVE 








ABSOLUTE, 




TLSU 


(P)E8 


TRANSFER 


3-83 






DESTRUCTIVE 








WHILE LESS, 




UABU 


(V)D9 


UNPACK 


3-99 






UPDATE 








ABSOLUTE, 




TNED 


(P)E5 


TRANSFER 


3-84 






UPDATE 








WHILE NOT 




USND 


(V)D0 


UNPACK 


3-99 






EQUAL, 








SIGNED, 








DESTRUCTIVE 








DESTRUCTIVE 




TNEU 


(P)ED 


TRANSFER 
WHILE NOT 
EQUAL, 
UPDATE 


3-84 


USNU 


(V)D8 


UNPACK 
SIGNED, 
UPDATE 


3-100 


TRNS 


(V)D7 


TRANSLATE 


3-101 










TUND 


(P)E6 


TRANSFER 

UNCONDITIONAI 

DESTRUCTIVE 


3-84 










TUNU 


(P)EE 


TRANSFER 


3-84 


VALC 


(P)00->3F 


VALUE CALL 


3-85 






UNCONDITIONAI 




VARI 


(P)95 


ESCAPE TO 16- 


3-96 






UPDATE 








BIT 




TWFD 


(V)D2 


TRANSFER 


3-84 






INSTRUCTION 








WHILE FALSE, 




VEBR 


(Z)EE 


VECTOR 


3-104 






DESTRUCTIVE 








BRANCH 




TWFU 


(V)DA 


TRANSFER 
WHILE FALSE, 
UPDATE 


3-84 


VMOM 


(Z)EF 


VECTOR MODE, 

MULTIPLE 

WORD 


3-76 


TWOD 


(P)D41 


TRANSFER 
WORDS 


3-83 


VMOS 


(Z)E7 


VECTOR MODE, 
SINGLE WORD 


3-76 






OVERWRITE, 




VXIT 


(Z)E6 


VECTOR EXIT 


3-105 






DESTRUCTIVE 




WHOI 


(V)4E 


READ 


3-98 


TWOU 


(P)DC 


TRANSFER 
WORDS 


3-83 






PROCESSOR 
IDENTIFICATION 








OVERWRITE, 




XTND 


(P)CE 


SET TO 


3-96 






UPDATE 








DOUBLE 




TWSD 


(P)D3 


TRANSFER 


3-82 






PRECISION 








WORDS, 




ZERO 


(P)B0 


LIT CALL 


3-78 






DESTRUCTIVE 








ZERO 





H-4 



APPENDIX I 



IOM WORD FORMATS 



HA WORD 1, START I/O COMMAND 



HA WORD 1, SET CHANNEL BUSY/RESERVED 





LK 

47 


043 


39 


35 


31 


27 


23 


19 


IS 


11 


7 


$ 


T50 


46 


K 


38 


UN 

34 


IT 

30 


26 


22 


16 


14 


10 


« 


2 


A 49 


4S 


C 

041 


37 


33 


;ig- 

29 


25 


21 


17 


13 


9 


5 


1 


G48 


44 


5 

£40 


36 


MA 

32 


TE 

28 


24 


30 


IS 


12 


8 


4 






FIELD 


BITS 


DESCRIPTION 


TAG 


50:3 


Denotes word is single precision 
(000). 



47:1 When set by software indicates the 
HA words are available for IOM 
use. Resets when IOM services HA 
words. 

46:3 Not used. 

43:4 Defines Start I/O command (0001). 

39:4 Not used. 

35:8 A unique 8-bit code-used with the 
UT base address to index and lock 
fetch from memory the UT word for 
the device to be started, and used 
with the QH base address to unlock 
fetch from memory the QH word, 
which points to the IOCB base 
address. 

27:28 Not used. 



HA WORD 1, SET CHANNEL BUSY/RESERVED 



LK 



HOME 
CODE 



UNIT 
DESIG- 
NATE 





LK 
47 


H 

043 


B/R 

39 


35 


31 


027 


23 


19 


15 


11 


7 


3 


T 50 


46 


M 
E42 


38 


34 


30 


H 

26 


22 


18 


14 


10 


6 


2 


A 49 


45 


$41 


37 


33 


29 


N25 


21 


17 


13 


9 


5 


1 


G 48 


44 


t40 


36 


32 


28 


0. 

24 


20 


16 


12 


8 


4 






FIELD BITS DESCRIPTION 

TAG 50:3 Denotes word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 

46:3 Not used. 

HOME 43:4 Defines Set CH Busy/Set CH 

CODE Reserved Commands (0010). 

B/R 39:1 When reset, further defines 

command as Set CH Busy; when 
set, further defines command as Set 
CH Reserved. 



38:11 Not used. 

CH. NO. 27:5 Identifies one of the 28 possible 
IOM channels. 

22:23 Not used. 



HA WORD 1, RESET CHANNEL 
RESERVED 





LK 

47 


H 
O43 


B/R 

39 


35 


31 


C27 


23 


19 


15 


11 


7 


3 


T 50 


46 


M 

E42 


38 


34 


30 


H. 

26 


22 


18 


14 


10 


6 


2 


A 49 


45 


c 

041 


37 


33 


29 


N25 


21 


17 


13 


9 


5 


1 


G 48 


44 


D 

E40 


36 


32 


28 


0. 

24 


20 


16 


12 


8 


4 






FIELD BITS 

TAG 50:3 



LK 



HOME 
CODE 

B/R 



CH. NO. 



47:1 



46:3 
43:4 

39:1 



38:11 
27:5 

22:23 



DESCRIPTION 

Denotes word is single precision 
(000). 

When set by software indicates the 
HA words are available for IOM 
use. Resets when IOM services HA 
words. 

Not used. 

Defines Reset CH Busy/Reset CH 
Reserved Commands (0011). 

When reset, further defines 
command as Reset CH Busy; when 
set, further defines command as 
Reset CH Reserved. 

Not used. 

Identifies one of the 28 possible 
IOM channels. 

Not used. 



HA WORD 1, LOAD BASE ADDRESS (HA, UT, 
UOQH, SQ) COMMANDS 





LK 

47 


043 


39 


35 


31 


21 


23 


19 


15 


11 


7 


3 


T 50 


40 


M 

E42 


38 


34 


30 


28 


22 


18 


ME 

14 


MO 

10 


RY 

6 


2 


A 49 


45 


Q41 


37 


33 


£9 


25 


21 


17 


*9, 


DR 

9 


5 


1 


G 48 


44 


D 

E40 


36 


32 


28 


24 


20 


16 


12 


8 


4 






FIELD BITS DESCRIPTION 

TAG 50:3 Denotes -word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 



1-1 



HA WORD 1, LOAD BASE ADDRESS (HA, UT, 
UOQH, SQ) COMMANDS 



HA WORD 2, DFO SCAN OUT/STORE 
CONTROL WORD REQUEST COMMAND 



HOME 
CODE 



46:3 Not used. 
43:4 Defines: 



(1) Load Home Address Command 
(0100) 

(2) Load Unit Table Address 
Command (0101) 

(3) Load I/O Queue Head Address 
Command (0110) 

(4) Load Status Queue Address 
(0111). 

— 39:20 Not used. 

MEMORY 19:20 The memory address to be stored in 
ADDRESS the Translator of the IOM to enable 

access of the IOM Job Map. 



HA WORD 1, DFO SCAN-OUT COMMANDS 
(CLEAR STACK AND STORE CW REQUEST) 





LK 

47 


H 
043 


39 


35 


31 


27 


23 


D 

v 19 


D 

F15 


Nil 


ES 

7 


3 


T 

50 


46 


M 

E42 


38 


34 


30 


26 


22 


f-18 


h 

U14 


U 

M io 


6 


2. 


A 

49 


45 


A41 


37 


33 


39 


25 


21: 


E 
X 17 


n» 


B 

F 9 


T 


1 


G 

48 


44 


E40 


36 


32 


28 


24 


20 


l» 


I 

fl2 


R 

8 


P 

E4 






FIELD BITS DESCRIPTION 

TAG 50:3 Denotes the word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 

_ 46:3 Not used. 

HOME 43:4 Defines the command as Scan Out 

CODE (DFO or DCP) when 1000. 

_ 39:20 Not used. 

DEVICE 19:4 Defines the Scan Out command is 

TYPE for a DFO (1001). 

DFEU 15:8, Together define the DFO by 

UNIT 7:1 specifying a DFEU unit number 

NMBR and whether it is directly (bit 7=0) 

and ES or indirectly (bit 7=1) connected to 

(EXCH the DFO. 

SELECT) 

_ 6:1 Not used. 

TYPE 5:2 Defines the DFO Scan-Out command 

as Clear the Stack (10) or Store 
Control Word Request (01). 

3:4 Not used. 





47 


43 


39 


35 


31 


27 


23 


19 


15 


11 


7 


3 


50 


46 


IOCI3 

42 38 34, 


30 


26 


22 


18 


DI15K 

14 10 


6 


2 


49 


45 


ADDRESS 

41 37 33 


29 


25 


21 


ADDFiES:> 

17 13 9 5 


1 


48 


44 


40 


36 


32 


28 


24 


20 


16 


12 


8 


4 






FIELD 


BITS 


DESCRIPTION 


— 


50:3 


Not used. 


IOCB 


47:20 


The base address of the job in 


ADDRESS 




memory. 


— 


27:2 


Not used. 


DISK 


25:26 


The disk address to be used for the 


ADDRESS 




job. 



NOTE 
This format also represents the format of 
the Scan Information word sent to the 
DFO. 

HA WORD 1, DCP SCAN-OUT COMMANDS 
(INITIATE, HALT, SET ATTENTION) 





LK 

47 


H 
043 


39 


35 


31 


: 27 


23 


D 

v 19 


15 


11 


?' 


D 

3 


T50 


46 


M 

E42 


38: 


34 


30 


26 


22 


CIS 


14 


10 


p 


P 

2 


A 

G49 


45 


41 


37 


33 


29 


25 


21 


Y 17 


13 


9 


E 
5 


N 
O.i 


48 


44 


£40 


36 


32 


28 


24 


20 


I» 


12 


8 


4 






FIELD BITS 

TAG 50:3 



LK 



47:1 



DESCRIPTION 

Denotes the word is single precision 
(000). 

When set by software indicates the 
HA words are available for IOM 
use. Resets when IOM services HA 
words. 



— 


46:3 


Not used. 


HOME 
CODE 


43:4 


Defines the command as Scan Out 
(DFO or DCP) when 1000. 


— 


39:20 


Not used. 


DEVICE 
TYPE 


19:4 


Defines the Scan Out command is 
for a DCP (110). 


— 


15:8 


Not used. 


TYPE 


7:3 


Defines the DCP Scan-Out commar 
as Initiate (000), Halt (010), or Set 
Attention (100). 


— 


4:1 


Not used. 


DCP NO. 


3:3 


Defines the DCP for which the 
command is intended. 





0:1 


Not used. 



1-2 



HA WORD 2, DCP SCAN -OUT/INITIATE 
COMMAND 



HA WORD 2 (SCAN-IN WORD), SCAN-IN DFO 
QUEUED CONTROL WORD AND TOP OF 
STACK COMMANDS 





47 


43 


39 


35 


31 


!!7 


23 


INSTRUCTION 

19 15| 11 7 3 






?« 


c« 


39 


33 


31 


27 


23 


19 


15 


11 


7 


3 


50 


46 


42 


38 


34 


30 


!!6 


22 


18 


base: 

14] 10 6 


2 




50 


T 

A 4 6 


h 
P« 


38 


34 


30 


26 


I 
22 


oc 

18 


3 

14 


10 


6 


2 


49 


45 


41 


37 


33 


29 


J! 5 


21 


17 


ADDRESS 

13 9 5 


1 


49 


T 

||45 




R41 


37 


33 


29 


25 


ADDRESS 

21 17 13 


9 


5 


1 


4a 


44 


40 


36 


32 


28 


K4 


20 


16 


12 


8 


4 





. .48 


8 « 


T 40 


39 


32 


28 


24 


20 


16 


12 


8 


4 


A o 



FIELD BITS DESCRIPTION 

50:31 Not used. 

INSTRUCTION 19:20 Define the memory base addre; 

BASE 

ADDRESS 



the DCP code. 



NOTE 
this format also represents the format of 
the Scan Information word sent to the 
DCP. 

HA WORD 1, DFO SCAN-IN COMMANDS 
(QUEUED CONTROL WORD, TOP OF STACK, 
REPORT) 





LK 

47 


H 
43 


39 


35 


31 


5:7 


23 


D 
El9 


D 
F15 


Nil 


ES 

7 


3 


T50 


46 


Dl — 
E 42 


38 


34 


30 


5:6 


22 


C 18 


U 14 


U 

Ml" 


© 


2 


A 49 


45 


C 
041 


37 


33 


29 


Si? 


21 


E 
T 17 


U 
N 13 


B 

E 9 


T 
Y 5 


i 


G 48 


44 


D 

e: 40 


36 


32 




28 


24 


20 


Y 
P16 


1 
T 12 


R 

8 


p 

E 4 






FIELD BITS DESCRIPTION 

TAG 50:3 Denotes i;he word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 

Not used. 

Defines the command as Scan in 
(1001). 

Not used. 

Defines the command as for a DFO 

(1001). 

Together define the DFO by 

specifying a DFEU unit number 

and whether it is directly or 
indirectly connected to the DFO (via 
an exchange). These fields are not 
used for the Scan-In DFO Report 
Command. 

Not used. 

Defines the DFO Scan-Out command 
as either Queued Control Word (01), 
Top of Stack (10), or Report (11). 

3:4 Not used. 



— 


46:3 


HOME 
CODE 


43:4 


— 


39:20 


DEVICE 

TYPE 

DFEU 

UNIT 


19:4 

15:8, 
7:1 


NMBR 

and ES 
(EXCH 
SELJ 




— 


6:1 


TYPE 


5:2 



FIELD 



STATUS 
REPORT 



BITS DESCRIPTION 

50:3 Not used. 

47:8 Describes the nature of the DFO by 
bits set as follows: 



(1) 47 set : 

(2) 46 set 

(3) 45 set 

(4) 44 set 

(5) 43 set 

(6) 42 set 
Word 

(7) 41 set 

(8) 40 set 
Available 

39:13 Not used. 



No Access to Exchange 
SU Not Available 
Parity Error 
Disk Address Error 
Queded Control Word 
Top of Stack Control 

Stack Empty 
Control Word Not 



IOCB 
ADDR 



A 
(ATTEN) 



26:20 Defines the memory address of the 
IOCB. 

6:6 Not used. 

0:1 When set, alerts the IOM to 

examine the STATUS REPORT 
FIELD. 



NOTE: 
This format also represents the format of 
the Scan Information word received from 
the DFO. 



HA WORD 2 SCAN-IN DFO REPORT 
COMMAND 





V 

47, 


43 


39 


s 

p35 


31 


27 


23 


19 


15 


11 


7 


3 


50 


P46 


V 42 


38 


C34 


f 30 


Qt 

26 


*R 

22 


18 


14 


10 


6 


2 


49 


R 

145 


P 
R41 


\ 


33 


r,29 


25 


21 


17 


13 


9 


5 


1 


48 


^44 


1 

2 40 


36 


V 

32 


C. 
28 


24 


20 


16 


12 


8 


4 






FIELD BITS DESCRIPTION 

50:3 Not used. 
V 47:1 When true indicates connection of 

an EU/DFO bus at port 1 and the 
EUs connected to this bus are 
referenced by the EUD code present 
on lines 43-46 of the Scan 
Information Lines. 

PRI 1 46:4 EUD code for port 1 bus (bit 

46=MSB). 



V 42:1 When true indicates connection of 

an EU/DFO bus at port 2 and the 
EUs connected to this bus are 
referenced by the EUD code present 
on lines 38-41. 

PRI 2 41:4 EUD code for port 2 bus (bit 

41=MSB). 

V 37:1 When true indicates connection of 

an EU/DFO bus at port 3, and the 
EUs connected to this bus are 
referenced by the EUD code present 
on lines 33-36. 

SEC 1 36:4 EUD code for port 3 bus (bit 

36=MSB) 

V 32:1 When true indicates connection of 

an EU/DFO bus at port 4, and the 
EUs connected to this bus are 
referenced by the EUD code present 
on lines 28-31. 

SEC 2 31:4 EUD code for port 4 bus (bit 

31=MSB). 



HOME 43:4 Defines the command as Sync I/O. 
CODE 

— 29:12 Not used. 

CHANNEL 27:5 Identifies one of the 28 possible 
NO. IOM channels. 

— 22:3 Not used. 

IOCB 19:20 The address of the job request in 
ADDRESS memory. 



HA WORD 1, INTERROGATE PERIPHERAL 
STATUS COMMAND 





LK 

47 


S 43 


39 


35 


31 


27 


23 


19 


IS 


V 
111 


7 


3 


Tso 


46 


M 

E42 


, 38 


34 


30 


26 


22 


18 


14 


OlO 


6 


2 


A 

Q49 

48 


45 
44 


Q41 

D 

F49 


r 37 


33 


39 


25 


21 


17 


K 

13 N0.9 


& 


1 


36 


32 


28 


24 


20 


16 


12 


8 


4 






QAR 



NOTE 
If a given EUD code appears on Scan Infor- 
mation lines 38-41 or 43-46, then the EUs 
referenced by the code are connected to the 
responding DFO in a direct manner, but if 
the EUD code appears on lines 28-31 or 33- 
36, then the EUs referenced by the EUD 
code are connected to the responding DFO 
indirectly (that is, via the other DFO of the 
DFO-pair). 

27:6 Indicates capacity of memory stack 
(bit 27=MSB). 

21:22 Not used. 



NOTE 
This format also represents the format of 
the Scan Information word received from 
the DFO. 

HA WORD 1, SYNC I/O COMMAND 





LK 

47 


H 
43 


39 


35 


31 


C 
H 27 


23 


19 


15 


11 


7 


3 


Tso 


46 


E42 


38 


34 


30 


N 26 


22 


18 


I 
14 


DCE 

10 


J 

6 


2 


A49 


45 


C 
41 


37 


33 


29 


E 
L 25 


21 


17 
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FIELD BITS DESCRIPTION 

TAG 50:3 Denotes the word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 

— 46:3 Not used. 



FIELD BITS DESCRIPTION 

TAG 50:3 Denotes the word is single precision 

(000). 

LK 47:1 When set by software indicates the 

HA words are available for IOM 
use. Resets when IOM services HA 
words. 

— 46:3 Not used. 

HOME 43:4 Defines Interrogate Peripheral 

CODE Status Command (1011). 

VECTOR 12:4 Defines the number of the status 
NO. vector to be interrogated. 

— 8:9 Not used. 

HA WORD 2 (STATUS WORD RETURNED), 
INTERROGATE PERIPHERAL STATUS 
COMMAND 
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FIELD 



STATUS 
BITS 



BITS 



DESCRIPTION 



ATT 



50:18 Not used. 

32:32 Each bit of this field, when on, 
indicates the ready status of the 
associated unit on the vector. (Refer 
to table 1-1 for referencing the 
ready status vector, ready status 
bit, and device number of any 
peripheral device.) 

0:1 When set, alerts the IOM to 

examine the STATUS BITS field. 



TABLE 1-1 . STATUS VECTOR CROSS REFERENCE 
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UNIT 127- 96 


































































DEST. 159-128 
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TO FIND THE STATUS VECTOR FOR A UD NUMBER, DIVIDE THE UD NUMBER BY 32. 
THE STATUS VECTOR IS THE INTERGER QUOTIENT AND THE VECTOR BIT IS THE 
REMAINDER PLUS ONE. 

EXAMPLE: UD NUMBER =95 

2 (STATUS VECTOR) 
32/95~ 
64 

31 + 1 = 32 (VECTOR BIT NUMBER) 

TO FIND THE UD NUMBER, MULTIPLY THE STATUS VECTOR NUMBER BY 32 AND 
ADD TO THE RESULT THE VECTOR BIT NUMBER MINUS ONE. 



EXAMPLE: STATUS VECTOR NUMBER = 2 

2 x 32 = 64 + (32-1 ) - 95 (UD NUMBER) 



HA WORD 1, INHIBIT IOM, ACTIVATE IOM, 
AND LOAD DFO FLAGS COMMANDS 



JB 



37:1 
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FIELD 

TAG 

LK 

HOME 
CODE 



BITS DESCRIPTION 

50:3 Denotes word is single precision 
(000). 

47:1 When set by software indicates the 
HA words are available for IOM 
services. 

43:4 Defines the command as follows: 



(1) 1100 = Inhibit IOM 

(2) 1101 = Activate IOM 

(3) 1110 = Load DFO Flags 



39:4 DFO Flags (for LOAD DFO FLAGS 
command only). 

35:36 Not Used. 



UNIT TABLE WORD 
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FIELD BITS DESCRIPTION 

TAG 50:3 Denotes word is single precision 

(000). 

LK 47:1 When set, indicates the UT word is 

being operated on. 

MGT 46:1 When set, indicates this job request 

is for a magnetic tape. (Set by 
software.) 

DSPK 45:1 When set, indicates this job request 

is for a disk pack. (Set by software.) 

SL 44:1 When set, indicates the presence of 

a side link in IOCB+1. 

— 43:4 Not used. 

DFO 39:1 When set, indicates unit is under 

control of a DFO. A ring walk will 
not be performed with this bit set. 
(Set by software.) 

EX 38:1 When set, indicates the unit is 

connected to an exchange. A ring 
walk will be performed (if the job 
bit is set) with this bit set. (Set by 
software.) Not used if bit 39 is set. 



BZ 


36:1 


FUD 


35:8 


CH. NO. 


27:5 


BASE 





LCEX 
RC 

LST 

NUD 

CH. NO. 
USED 

ET 



22:2 

20:1 

19:3 
16:1 

15:8 

7:5 

2:2 
0:1 



IOQH WORD 



When set, indicates that all 
channels associated with this 
request were busy, and when a 
channel becomes free and no 
further request are queued for that 
device, this job is to be done. (Set 
by IOM.) 

Used only with exch. devices (Bit 
38=1). Not used with DFO (Bit 39). 

When set, indicates that this unit is 
busy. (Set by IOM.) 

Points to the First Unit Designate 
Number connected to the exchange. 

For units not on an exchange, the 
number of the channel to which 
this unit is connected. For units on 
an exchange, the lowest numbered 
channel to which the exchange is 
connected. 

NOTE: CN and 21 through 23 are 
unassigned and will cause a fail. 

Indicates the 2 least significant bits 
of the last channel number of the 
exchange, for the device to be used. 

When set, permits this unit to use a 
reserved channel. 

Not used. 

When set, indicates this is the last 
Unit Designate on the exchange. 

Points to the Next Unit Designate 
number connected to the exchange. 

These bits specify the channel that 
was used to service the device. (Set 
by IOM.) 

Not used. 

When set, indicates that an error 
condition has been reported in the 
current Result Descriptor, and 
therefore additional jobs should not 
be initiated for the unit. This bit is 
normally reset by software. 
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FIELD BITS DESCRIPTION 

TAG 50:3 Denotes word is single precision 
(000). 

— 47:28 Not used. 

ADDRESS 19:2 ° Address of 1st IOCB in the IOQ. If 
OF bits 19-0 are null (zero), the UT 

FIRST word is unlocked and restored to 

IOCB memory. 
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IOQT WORD 





47 


43 


39 


35 


31 


37 


23 


19 


15 


11 


7 


3 


J50 


46 


42 


38 


34 


30 


26 


22 


ACiD. 

18 14 


10 


LAI5T 

6 2 


A 49 


45 


41 


37 


33 


29 


J5 


21 


17 


I 
13 


OCI) 

9 5 


1 


G 48 


44 


40 


36 


32 


28 


24 


20 


16 


12 


8 


4 






FIELD 
TAG 


BITS 

50:3 





47:28 


ADD 
OF 
LAST 
IOCB 


19:20 


SQH WORD 



DESCRIPTION 

Denotes word is single 
precision (000). 

Not used. 

Address of last IOCB in the 
IOQ. 
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FIELD 
TAG 

LK 



BITS 

50:3 
47:1 



— 


46:1 


c 


45:1 


CPM 
NO. 


44:3 


NULL 


41:1 



INT 



40:1 



HEAD 39:20 



TAIL 19:20 



DESCRIPTION 

Denotes word is single 
precision (000). 

When set, indicates the SQB 
word is being operated on. 

Not used. 

Notifies software, when set, 
that a status change vector 
has occurred. 

Points to the CPM that will 
be interrupted by either 
channel interrupt or error 
interrupt. 

When a 0, indicates that the 
queue is empty; when a 1, 
indicates terminated jobs are 
under queue. 

When set, (set by software) 
indicates that the CPM 
number field shall be 
interrupted upon job 
termination. (Reset by IOM) 

A 20-bit address pointing to 
the IOCB of the first device 
terminated. (Not used if bit 
41 = 0) 

A 20-bit address pointing to 
the IOCB of the last device 
terminated. (Not used if 41 

= 0) 



IOCB WORD O (IOCB I/O LINKAGE (N/L) 
WORD) 





47 


43 


39 


35 


31 


27 


23 


19 


15 


11 


7 


3 


T50 


46 


42 


38 


34, 


30 


26 


22 


18 


N 

14 


EXT 

10 6 


2 


A 49 


45 


41 


37 


33 


29 


J5 


21 


17 


LINK 

13 9 5 


1 


G 

48 


44 


INT 

40 


36 


32 


28 


24 


20 


16 


12 


8 


4 






FIELD BITS DESCRIPTION 

TAG 50:3 Denotes word is single 

precision (000). 

— 47:7 Not used. 

INT 40:1 When set, notifies the IOM 

to interrupt the CPM 
specified in the SQ word 
upon completion of this job. 

— 39:20 Not used. 

NEXT 19:20 Memory address of the next 
LINK job (IOCB) queued for this 

device. 



IOCB WORD 1 (IOCB SIDELINK (SL) WORD) 
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FIELD 

TAG 


BITS 
50:3 


UNIT 47:8 
DESIGNATE 


SIDE 
LINK 


39:20 


- 


19:12 


IOM 
MASK 


7:8 



DESCRIPTION 

Denotes the word is single 
precision (000). 

Defines the device which is 
to perform this sidelinked 
job. 

Memory address of the 
sidelinked job. 

Not used. 

Defines an IOM channel 
number and thus defines the 
IOM (or IOM's) which can 
perform the sidelinked job. 

1-7 



I/O CONTROL BLOCK (IOCB) 



BASE ADDRESS ( BA) 



/BA+1 , BA + 2 ,BA+3 -BA + 4 ,BA+5 

Z jL JL- jL I 



I/O LINKAGE 
(NL) 



SIDELINK 



BUFFER 
DESCRIPTOR 



IOCW 



CDL 



IORD 




47 47 47 47 47 47 

WORD I WORD I I WORD 2 ! WORD 3 WORD 4 WORD 5 



* WORDS 6 THRU N ARE RESERVED FOR SOFTWARE USE ONLY 



IOCB WORD 2 (IOCB BUFFER DESCRIPTOR 
(BD) WORD) 





47 


43 


c 

J39 


35 


31 


27 


23 


19 


15 


11 


7 


3 


Tso 


46 


43 


v38 


34 


LEN 

30 


GTH 

26 


22 


18 


E 

14 


ASI 

10 


6 


2 


A 

G49 


45 


41 


'37 


33 


29 


25 


21 


17 


AD 

13 


DRE 

9 


ss 

5 


1 


4? 


44 


40 


36 


32 


28 


24 


20 


16 


12 


8 


4 






FIELD 


BITS 


TAG 


50:3 


_ 


47:8 


CT 


39:3 


EXT 





DESCRIPTION 

Denotes word is single 
precision (000). 

Not used. 

If the length of the buffer 
includes a fractional part of 
a word, this field describes 
the number of characters in 
that fractional part. 

36:17 Describes the length of the 
buffer in words. (Excess 
characters are described by 
the CT EXT field.) 

BASE 19:20 Describes the memory 
ADDRESS address of the first data 

word of the buffer. 

IOCW (IOCB WORD 3) 



LENGTH 
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FIELD BITS DESCRIPTION 

TAG 50:3 Denotes the word is single 

precision (000). 

ASC 47:1 When set, indicates that 

ASCII translation is 
required. 

SL 46:1 When set, indicates that a 

sidelink to another IOCW is 
required. (The address of the 
new IOCW is stored in bits 
thru 19 of the IOCB SL 
word.) 

SA 45:1 When set, will cause bit 1 of 

the result descriptor word 
(the Exception bit) to be set. 



I/O 44:1 When set, indicates that the 

transfer is to be an input 
operation. When reset, 
indicates that the transfer is 
to be an output operation. 

When set, indicates that 
data will not be transferred 
to/from memory. 

42:1 When set, indicates that 

internal IOM translation is 
needed. 

FML 41:1 When set, indicates that the 

frame length is to be 8-bits. 
When reset, indicates that 
the frame length is to be 6- 
bits. 



MINH 43:1 



TRA 



1-8 



MP 



B/F 



40:1 When set, indicates that a 
memory protect interrupt 
will occur if an attempt is 
made to store into a word in 
memory which has bit 48 = 
1. The store will not occur. 

39:1 When set, indicates a 

backward operation on a 
tape unit. When reset, 
indicates a forward operation 
on a tape unit. 

38:1 When set, indicates a test 
operation. 

37:2 Indicates the following: 

37 3€i 

Store single precision ta 

1 1 Store double precision 
tags 

1 Store program tags 

1 Tag field transfer 

35:36 Not used. 



UNIT CONTROL WORD (UCW) 



WRT 20:1 



L1A 19:20 



Shall identify the service 
request as a Read (WRT=0) 
or Write (WRT=1) operation. 

Shall specify the absolute 
starting memory address of 
the transfer. 



MEMORY CONTROL WORD 



TAG 

CTL 
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FIELD 
LGT 



MP 



BITS DESCRIPTION 

23:2 Specify the total length of 
the field being transferred 
as follows: 

23 22 

1= Transfer 1 word 

10= Transfer 2 words 

21:1 On a one or two word store, 
if bit 48 of the information 
word already stored in that 
memory location is a one 
(protected word), memory 
shall not perform the store 
but shall send an error 
signal to the requestor. 



FIELD BITS 

TAG 50:3 



W 47:1 

(Write) 



TYPE 46:1 



SP 45:1 

(Specifier) 



WP 44:1 

(Write 

Protect) 



DESCRIPTION 

Not significant for control 
purposes; examined only for 
generation of parity. 

When a specifies that a 
read/restore operation is to 
be performed. When a 1, 
specifies that one of the 
write variations, as defined 
by the TYPE field, is to be 
performed. 

When the W field is a 1, 
specifies which write 
variation is to be performed 
as follows: when 46=0, a 
Clear/Write operation shall 
be performed (the Overwrite 
and Single-Word protected 
Write operations use this 
variation). When 46=1, a 
Read/Modify/Restore 
operation shall be performed 
(the N-Word Protected Write 
operation uses this 
variation). When the field is 
a and 46=1, the contents 
of the Fail Register are 
fetched. 

When a 1, indicates that a 

single-word operation is to 
be performed. When a 0, 
indicates that an N-word 
operation is to be performed. 

When a 1, indicates that a 
Protected Write operation is 
to be performed. It is a if 
any other type of operation 
is specified. 



1-9 



FB 43:1 

(Flashback) 



RIL 42:1 

(Requestor 
Inhibit 
Load) 



When a 1, specifies that the 
original contents of the 
memory location are to be 
sent to the requestor. 

Used in a Single-Word 
Overwrite operation to 
specify that a Load 
Requestor operation is to be 
performed. When a 1, 
specifies that the next data 
word sent to the MCM be 
loaded into the Requestor 
Inhibit Register instead of 
into memory. 

MLL 41:1 When a 1, specifies that the 

(Memory next data word sent to the 

Limits MCM be loaded into the 

Load) Memory Limit Registers and 

the Available Register, 
instead of into memory. 

ADDRESS 36:20 Specify the starting address 
for the memory operation. 

AR 16:2 

(Address 
Residue) 



FC 



6:1 Not used. 

5:2 Function code which defines 
the operation as follows: 

(1) During Scan-Out: 

5 4 

1 = Store CW Request 

10 = Clear-the-Stack 

(2) During Scan-In: 

5 4 

1 = Queued CW 
Request 

1 
Request 

1 1 

3:4 Not used. 



= Top-of-Stack 
= Report Request 



WLG 

(Word 

Length) 



Indicate the proper value 
(00, 01, or 10) that result 
from changes in the 
ADDRESS field. 

14:12 Not used. 

2:3 Indicates the number of 
words to be transferred 
during memory operations (2 
words maximum). 



NOTE 
The format of the DFO Scan Ad- 
dress word may be related directly 
to bits through 19 of HA word 1, 
when HA word 1 contains a com- 
mand for DFO scan-out or scan-in. 

DCP SCAN ADDRESS WORD 



DFO SCAN ADDRESS WORD (SCAN-IN AND 
SCAN-OUT) 
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FIELD 

DT 
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FIELD 
DT 



FC 



BITS 

19:4 



EUD 15:8, 

NO. 7:1 

AND 

ES 

(EXCHANGE 

SELECT) 



DESCRIPTION 

Identifies the information as 
for a DFO (1001). 

Together define the DFO by 
specifying a DFEU unit 
designate number and 
whether it is directly or 
indirectly connected to 
DFO (via an exchange). 
These fields are not used if 
Scan-In DFO Report is the 
job to be implemented. 



DCP 
ADDR 



BITS DESCRIPTION 

19:4 Defines the Scan-Out 
command is for a DCP 
(1100). 

15:8 Not used. 

7:3 Defines the DCP Scan-Out 
command as Initiate (000), 
Halt (010), or Set Attention 
(100). 

4:1 Not used. 

3:3 Defines the DCP for which 
the command is intended. 

0:1 Not used. 



NOTE 
The format of the DCP Scan Ad- 
dress word may be related directly 
to bits through 19 of HA word 1, 
when HA word 1 contains a DCP 
scan-out command. 
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